public class PaginationServiceImpl extends Object implements PaginationServiceInternal
Constructor and Description |
---|
PaginationServiceImpl(org.springframework.transaction.PlatformTransactionManager transactionManager) |
Modifier and Type | Method and Description |
---|---|
<F,T> Paginated<T> |
createPaginated(PaginationBatch<F> fetchBatch,
com.google.common.base.Function<? super F,T> modelConverter,
int maxLimit)
Constructs a Paginated implementation backed by the given PaginationBatch.
|
<F,T> PagingIterator<T> |
createPagingIterator(PaginationBatch<F> fetchBatch,
int resultsPerPage,
com.google.common.base.Function<? super F,T> modelConverter)
Constructs a PagingIterator backed by the given PaginationBatch.
|
<H,M> PageResponse<M> |
doPaginationRequest(LimitedRequest initialRequest,
PaginationBatch<H> fetchPage,
com.google.common.base.Function<? super H,M> modelConverter)
Perform a pagination request, this will execute the fetchBatch function as many times as
necessary to retrieve the page of results.
|
public PaginationServiceImpl(org.springframework.transaction.PlatformTransactionManager transactionManager)
public <H,M> PageResponse<M> doPaginationRequest(LimitedRequest initialRequest, PaginationBatch<H> fetchPage, com.google.common.base.Function<? super H,M> modelConverter)
PaginationService
com.atlassian.confluence.api.model.pagination.LimitedRequest.getMaxLimit()
results
from the datasource. FetchBatch will be executed in a new transaction for each batch to prevent excessive memory usage.
It is expected that any permission checking is performed in the PaginationBatch.
The PaginationService is responsible for ensuring that enough results are returned from the PaginationBatch to fulfill the request. The PaginationBatch should not treat the pageRequest getStart and getLimit values as user specific indexes, only results the user can see should be returned. If a user does not have permission to see any results in the requested range an empty list should be returned in the response and the hasMore flag set if there are more results still to check. The pagination service will call again if more results are required.
doPaginationRequest
in interface PaginationService
initialRequest
- - a request for a range of datafetchPage
- - the function to supply the resultsmodelConverter
- - a function to convert from the supplied object to a model object, this will be executed within a transaction.public <F,T> PagingIterator<T> createPagingIterator(PaginationBatch<F> fetchBatch, int resultsPerPage, com.google.common.base.Function<? super F,T> modelConverter)
PaginationServiceInternal
createPagingIterator
in interface PaginationServiceInternal
fetchBatch
- - a request for a range of dataresultsPerPage
- - number of results to request from PaginationBatch each invocation.modelConverter
- - a function to convert from the supplied object to a model object, this will be executed within a transaction.com.atlassian.confluence.api.model.pagination.PagingIterator
public <F,T> Paginated<T> createPaginated(PaginationBatch<F> fetchBatch, com.google.common.base.Function<? super F,T> modelConverter, int maxLimit)
PaginationServiceInternal
createPaginated
in interface PaginationServiceInternal
fetchBatch
- - a request for a range of datamodelConverter
- - a function to convert from the supplied object to a model object, this will be executed within a transaction.maxLimit
- - the max limit to apply when creating LimitedRequests for paged requests from the Paginated.com.atlassian.confluence.api.model.pagination.Paginated
Copyright © 2003–2016 Atlassian. All rights reserved.