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

io.sphere.sdk.queries.PagedResult Maven / Gradle / Ivy

There is a newer version: 1.0.0-M26
Show newest version
package io.sphere.sdk.queries;

import io.sphere.sdk.models.Base;

import java.util.List;
import java.util.Optional;

public abstract class PagedResult extends Base {
    protected final Long offset;
    protected final Long total;
    protected final List results;

    protected PagedResult(final Long offset, final Long total, final List results) {
        this.offset = offset;
        this.total = total;
        this.results = results;
    }

    /**
      * The offset supplied by the client or the server default.
      * @return the amount of items (not pages) skipped
      */
     public Long getOffset() {
         return offset;
     }

    /**
      * The actual number of results returned.
      * @return the number of elements in this container
      */
     public Long size() {
         return (long) results.size();
     }

    /**
      * The total number of results matching the request.
      * Total is greater or equal to count.
      * @return the number of elements that can be fetched matching the criteria
      */
     public Long getTotal() {
         return total;
     }

    /**
      * List of results. If {@link io.sphere.sdk.queries.PagedResult#size()} is not equal
      * to {@link io.sphere.sdk.queries.PagedResult#getTotal()} the container contains only a subset of all
      * elements that match the request.
      * @return {@link io.sphere.sdk.queries.PagedResult#size()} elements matching the request
      */
     public List getResults() {
         return results;
     }

    /**
      * Tries to access the first element of the result list.
      * Use case: query by slug which should contain zero or one element in the result list.
      * @return the first value or absent
      */
     public Optional head() {
         return results.isEmpty() ? Optional.empty() : Optional.of(results.get(0));
     }

    /**
      * Checks if this is the first page of a result.
      * @return true if offset is 0 otherwise false
      */
     public boolean isFirst() {
         if (getOffset() == null) {
             throw new UnsupportedOperationException("Can only be used if the offset is known.");
         }
         return getOffset() == 0;
     }

    /**
      * Checks if it is the last possible page.
      * @return true if doing a request with an incremented offset parameter would cause an empty result otherwise false.
      */
     public boolean isLast() {
         if (getOffset() == null || getTotal() == null) {
             throw new UnsupportedOperationException("Can only be used if the offset & total is known.");
         }
         //currently counting the total amount is performed in a second database call, so it is possible
         //that the left side can be greater than total
         return getOffset() + size() >= getTotal();
     }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy