/*******************************************************************************
* Gisgraphy Project
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA
*
* Copyright 2008 Gisgraphy project
* David Masclet <davidmasclet@gisgraphy.com>
*
*
*******************************************************************************/
package com.gisgraphy.dao;
import java.io.Serializable;
import java.util.List;
/**
* Data Access Object (DAO) interface.
*
* @author <a href="mailto:matt@raibledesigns.com">Matt Raible</a>
* Modifications and comments by <a href="mailto:bwnoll@gmail.com">Bryan
* Noll</a> This thing used to be named simply 'GenericDao' in versions
* of appfuse prior to 2.0. It was renamed in an attempt to distinguish
* and describe it as something different than GenericDao. GenericDao is
* intended for subclassing, and was named Generic because 1) it has
* very general functionality and 2) is 'generic' in the Java 5 sense of
* the word... aka... it uses Generics. Implementations of this class
* are not intended for subclassing. You most likely would want to
* subclass GenericDao. The only real difference is that instances of
* java.lang.Class are passed into the methods in this class, and they
* are part of the constructor in the GenericDao, hence you'll have to
* do some casting if you use this one.
* @see com.gisgraphy.dao.GenericDao
*/
public interface UniversalDao {
/**
* Generic method used to get all objects of a particular type. This is the
* same as lookup up all rows in a table.
*
* @param clazz
* the type of objects (a.k.a. while table) to get data from
* @return List of populated objects
*/
List<?> getAll(Class<?> clazz);
/**
* Generic method to get an object based on class and identifier. An
* ObjectRetrievalFailureException Runtime Exception is thrown if nothing is
* found.
*
* @param clazz
* model class to lookup
* @param id
* the identifier (primary key) of the class
* @return a populated object
* @see org.springframework.orm.ObjectRetrievalFailureException
*/
Object get(Class<?> clazz, Serializable id);
/**
* Generic method to save an object - handles both update and insert.
*
* @param o
* the object to save
* @return a populated object
*/
Object save(Object o);
/**
* Generic method to delete an object based on class and id
*
* @param clazz
* model class to lookup
* @param id
* the identifier (primary key) of the class
*/
void remove(Class<?> clazz, Serializable id);
}