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

software.amazon.awssdk.services.databasemigration.paginators.DescribeOrderableReplicationInstancesIterable 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.

The newest version!
/*
 * Copyright 2013-2018 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.paginators;

import java.util.Collections;
import java.util.Iterator;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.pagination.sync.PaginatedResponsesIterator;
import software.amazon.awssdk.core.pagination.sync.SdkIterable;
import software.amazon.awssdk.core.pagination.sync.SyncPageFetcher;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructMap;
import software.amazon.awssdk.services.databasemigration.DatabaseMigrationClient;
import software.amazon.awssdk.services.databasemigration.model.DescribeOrderableReplicationInstancesRequest;
import software.amazon.awssdk.services.databasemigration.model.DescribeOrderableReplicationInstancesResponse;

/**
 * 

* Represents the output for the * {@link software.amazon.awssdk.services.databasemigration.DatabaseMigrationClient#describeOrderableReplicationInstancesPaginator(software.amazon.awssdk.services.databasemigration.model.DescribeOrderableReplicationInstancesRequest)} * operation which is a paginated operation. This class is an iterable of * {@link software.amazon.awssdk.services.databasemigration.model.DescribeOrderableReplicationInstancesResponse} that * can be used to iterate through all the response pages of the operation. *

*

* When the operation is called, an instance of this class is returned. At this point, no service calls are made yet and * so there is no guarantee that the request is valid. As you iterate through the iterable, SDK will start lazily * loading response pages by making service calls until there are no pages left or your iteration stops. If there are * errors in your request, you will see the failures only after you start iterating through the iterable. *

* *

* The following are few ways to iterate through the response pages: *

* 1) Using a Stream * *
 * {@code
 * software.amazon.awssdk.services.databasemigration.paginators.DescribeOrderableReplicationInstancesIterable responses = client.describeOrderableReplicationInstancesPaginator(request);
 * responses.stream().forEach(....);
 * }
 * 
* * 2) Using For loop * *
 * {
 *     @code
 *     software.amazon.awssdk.services.databasemigration.paginators.DescribeOrderableReplicationInstancesIterable responses = client
 *             .describeOrderableReplicationInstancesPaginator(request);
 *     for (software.amazon.awssdk.services.databasemigration.model.DescribeOrderableReplicationInstancesResponse response : responses) {
 *         // do something;
 *     }
 * }
 * 
* * 3) Use iterator directly * *
 * {@code
 * software.amazon.awssdk.services.databasemigration.paginators.DescribeOrderableReplicationInstancesIterable responses = client.describeOrderableReplicationInstancesPaginator(request);
 * responses.iterator().forEachRemaining(....);
 * }
 * 
*

* Note: If you prefer to have control on service calls, use the * {@link #describeOrderableReplicationInstances(software.amazon.awssdk.services.databasemigration.model.DescribeOrderableReplicationInstancesRequest)} * operation. *

*/ @Generated("software.amazon.awssdk:codegen") public class DescribeOrderableReplicationInstancesIterable implements SdkIterable { private final DatabaseMigrationClient client; private final DescribeOrderableReplicationInstancesRequest firstRequest; private final SyncPageFetcher nextPageFetcher; public DescribeOrderableReplicationInstancesIterable(DatabaseMigrationClient client, DescribeOrderableReplicationInstancesRequest firstRequest) { this.client = client; this.firstRequest = firstRequest; this.nextPageFetcher = new DescribeOrderableReplicationInstancesResponseFetcher(); } @Override public Iterator iterator() { return PaginatedResponsesIterator.builder().nextPageFetcher(nextPageFetcher).build(); } /** *

* A helper method to resume the pages in case of unexpected failures. The method takes the last successful response * page as input and returns an instance of {@link DescribeOrderableReplicationInstancesIterable} that can be used * to retrieve the consecutive pages that follows the input page. *

*/ private final DescribeOrderableReplicationInstancesIterable resume( DescribeOrderableReplicationInstancesResponse lastSuccessfulPage) { if (nextPageFetcher.hasNextPage(lastSuccessfulPage)) { return new DescribeOrderableReplicationInstancesIterable(client, firstRequest.toBuilder() .marker(lastSuccessfulPage.marker()).build()); } return new DescribeOrderableReplicationInstancesIterable(client, firstRequest) { @Override public Iterator iterator() { return Collections.emptyIterator(); } }; } private class DescribeOrderableReplicationInstancesResponseFetcher implements SyncPageFetcher { @Override public boolean hasNextPage(DescribeOrderableReplicationInstancesResponse previousPage) { return previousPage.marker() != null && !SdkAutoConstructList.class.isInstance(previousPage.marker()) && !SdkAutoConstructMap.class.isInstance(previousPage.marker()); } @Override public DescribeOrderableReplicationInstancesResponse nextPage(DescribeOrderableReplicationInstancesResponse previousPage) { if (previousPage == null) { return client.describeOrderableReplicationInstances(firstRequest); } return client.describeOrderableReplicationInstances(firstRequest.toBuilder().marker(previousPage.marker()).build()); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy