
com.oracle.bmc.announcementsservice.AnnouncementPaginators Maven / Gradle / Ivy
/**
* Copyright (c) 2016, 2021, Oracle and/or its affiliates. All rights reserved.
* This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
*/
package com.oracle.bmc.announcementsservice;
import com.oracle.bmc.announcementsservice.requests.*;
import com.oracle.bmc.announcementsservice.responses.*;
/**
* Collection of helper methods that can be used to provide an {@link java.lang.Iterable} interface
* to any list operations of Announcement where multiple pages of data may be fetched.
* Two styles of iteration are supported:
*
*
* - Iterating over the Response objects returned by the list operation. These are referred to as ResponseIterators, and the methods are suffixed with ResponseIterator. For example: listUsersResponseIterator
* - Iterating over the resources/records being listed. These are referred to as RecordIterators, and the methods are suffixed with RecordIterator. For example: listUsersRecordIterator
*
*
* These iterables abstract away the need to write code to manually handle pagination via looping and using the page tokens.
* They will automatically fetch more data from the service when required.
*
* As an example, if we were using the ListUsers operation in IdentityService, then the {@link java.lang.Iterable} returned by calling a
* ResponseIterator method would iterate over the ListUsersResponse objects returned by each ListUsers call, whereas the {@link java.lang.Iterable}
* returned by calling a RecordIterator method would iterate over the User records and we don't have to deal with ListUsersResponse objects at all.
* In either case, pagination will be automatically handled so we can iterate until there are no more responses or no more resources/records available.
*/
@javax.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 0.0.1")
@lombok.RequiredArgsConstructor
public class AnnouncementPaginators {
private final Announcement client;
/**
* Creates a new iterable which will iterate over the responses received from the listAnnouncements operation. This iterable
* will fetch more data from the server as needed.
*
* @param request a request which can be sent to the service operation
* @return an {@link java.lang.Iterable} which can be used to iterate over the responses received from the service.
*/
public Iterable listAnnouncementsResponseIterator(
final ListAnnouncementsRequest request) {
return new com.oracle.bmc.paginator.internal.ResponseIterable<
ListAnnouncementsRequest.Builder, ListAnnouncementsRequest,
ListAnnouncementsResponse>(
new com.google.common.base.Supplier() {
@Override
public ListAnnouncementsRequest.Builder get() {
return ListAnnouncementsRequest.builder().copy(request);
}
},
new com.google.common.base.Function() {
@Override
public String apply(ListAnnouncementsResponse response) {
return response.getOpcNextPage();
}
},
new com.google.common.base.Function<
com.oracle.bmc.paginator.internal.RequestBuilderAndToken<
ListAnnouncementsRequest.Builder>,
ListAnnouncementsRequest>() {
@Override
public ListAnnouncementsRequest apply(
com.oracle.bmc.paginator.internal.RequestBuilderAndToken<
ListAnnouncementsRequest.Builder>
input) {
if (input.getToken() == null) {
return input.getRequestBuilder().build();
} else {
return input.getRequestBuilder()
.page(input.getToken().orNull())
.build();
}
}
},
new com.google.common.base.Function<
ListAnnouncementsRequest, ListAnnouncementsResponse>() {
@Override
public ListAnnouncementsResponse apply(ListAnnouncementsRequest request) {
return client.listAnnouncements(request);
}
});
}
/**
* Creates a new iterable which will iterate over the {@link com.oracle.bmc.announcementsservice.model.AnnouncementSummary} objects
* contained in responses from the listAnnouncements operation. This iterable will fetch more data from the
* server as needed.
*
* @param request a request which can be sent to the service operation
* @return an {@link java.lang.Iterable} which can be used to iterate over the {@link com.oracle.bmc.announcementsservice.model.AnnouncementSummary} objects
* contained in responses received from the service.
*/
public Iterable
listAnnouncementsRecordIterator(final ListAnnouncementsRequest request) {
return new com.oracle.bmc.paginator.internal.ResponseRecordIterable<
ListAnnouncementsRequest.Builder, ListAnnouncementsRequest,
ListAnnouncementsResponse,
com.oracle.bmc.announcementsservice.model.AnnouncementSummary>(
new com.google.common.base.Supplier() {
@Override
public ListAnnouncementsRequest.Builder get() {
return ListAnnouncementsRequest.builder().copy(request);
}
},
new com.google.common.base.Function() {
@Override
public String apply(ListAnnouncementsResponse response) {
return response.getOpcNextPage();
}
},
new com.google.common.base.Function<
com.oracle.bmc.paginator.internal.RequestBuilderAndToken<
ListAnnouncementsRequest.Builder>,
ListAnnouncementsRequest>() {
@Override
public ListAnnouncementsRequest apply(
com.oracle.bmc.paginator.internal.RequestBuilderAndToken<
ListAnnouncementsRequest.Builder>
input) {
if (input.getToken() == null) {
return input.getRequestBuilder().build();
} else {
return input.getRequestBuilder()
.page(input.getToken().orNull())
.build();
}
}
},
new com.google.common.base.Function<
ListAnnouncementsRequest, ListAnnouncementsResponse>() {
@Override
public ListAnnouncementsResponse apply(ListAnnouncementsRequest request) {
return client.listAnnouncements(request);
}
},
new com.google.common.base.Function<
ListAnnouncementsResponse,
java.util.List<
com.oracle.bmc.announcementsservice.model.AnnouncementSummary>>() {
@Override
public java.util.List<
com.oracle.bmc.announcementsservice.model.AnnouncementSummary>
apply(ListAnnouncementsResponse response) {
return response.getAnnouncementsCollection().getItems();
}
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy