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

br.com.arsmachina.controller.ReadableController Maven / Gradle / Ivy

// Copyright 2008-2013 Thiago H. de Paula Figueiredo
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License 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 br.com.arsmachina.controller;

import java.io.Serializable;
import java.util.List;

import br.com.arsmachina.dao.SortCriterion;


/**
 * Interface that defines a read-only, generic and generified controller for a given entity class.
 * 
 * @author Thiago H. de Paula Figueiredo
 * @param  the entity class related to this controller.
 * @param  the type of the field that represents the entity class' primary key.
 */

public interface ReadableController {
	
	/**
	 * Returns the total number of objects of this class.
	 * @return an int.
	 */
	long countAll();

	/**
	 * Returns the object with a given primary key value.
	 * 
	 * @param id a K.
	 * @return a T.
	 */
	T findById(K id);

	/**
	 * Returns the all instances of the related entity class.
	 * 
	 * @return a {@link List} of T.
	 */
	List findAll();

	/**
	 * Returns the objects with some given primary key values.
	 * 
	 * @param ids a K array.
	 * @return a {@link List} of T.
	 */
	List findByIds(K... ids);
	
	/**
	 * Executes a query by example.
	 * 
	 * @param example a T.
	 * @return a {@link List} of T.
	 */
	List findByExample(T example);

	/**
	 * Returns the all instances of the related entity class, but in a paginated fashion.
	 * 
	 * @param firstResult an int with the index of the first object to be returned.
	 * The first object has index 0.
	 * @param maxResults an int with the maximum number of objects to be returned.
	 * @param sortConstraints an {@link SortConstraint} array used to define how the returned list
	 * will be sorted.
	 * @return a {@link List} of T.
	 */
	List findAll(int firstResult, int maxResults, SortCriterion... sortConstraints);
	
	/**
	 * Reattaches an object to the persistence context, if there is one. The object store
	 * must not be changed. The attached object, which not necessarily is the one passed
	 * as a parameter, is returned.
	 * 
	 * @param object a T.
	 * @return object a T.
	 */
	T reattach(T object);
	
	/**
	 * Refreshes an object, getting the most recent version of its data from the object store.
	 * It should return the same object passed as a parameter, overwritten with the most recent data,
	 * if possibile, but this isn't a requirement.
	 *  
	 * @param object a T
	 * @return a T, which may or may not be the same object passed in the parameter.
	 */
	T refresh(T object);
	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy