
br.com.arsmachina.controller.WriteableController 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;
/**
* Interface that defines a read-write, 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 WriteableController {
/**
* Removes an object.
*
* @param object a T
.
*/
void delete(T object);
/**
* Removes an object given its primary key.
*
* @param id a K
.
*/
void delete(K id);
/**
* Saves (inserts) an object.
*
* @param object a T
*/
void save(T object);
/**
* Updates an object. If it is not persistent, an {@link IllegalArgumentException} is thrown.
* The return value must be the object that is attached to the persistence context of the
* underlying implementation, if it exists. Otherwise, this method simply returns the object
* passed as a parameter. This return value was added to deal ORM frameworks like JPA, that do
* not attach the updated object to the persistence context. See
* EntityManager.merge()
.
*
* @param object a T
.
* @return a T
.
* @throws IllegalArgumentException if object
is null or not persistent.
*/
T update(T object);
/**
* Saves (inserts) or updates an object. If it is already persistent, it is updated. Otherwise,
* it is saved (inserted). The return value must be the object that is attached to the
* persistence context of the underlying implementation, if it exists. Otherwise, this method
* simply returns the object passed as a parameter. This return value was added to deal ORM
* frameworks like JPA, that do not attach the updated object to the persistence context. See
* EntityManager.merge()
.
*
* @return a T
.
* @param object a T
* @throws IllegalArgumentException if object
is null.
*/
T saveOrUpdate(T object);
/**
* Removes an object from the current persistence context. This method only has meaningful
* implementations when used with ORM frameworks that have an evict concept (Hibernate, JPA,
* etc).
*
* @param object a T
.
* @return a T
.
*/
void evict(T object);
/**
* Tells whether a given object is already persistent or not.
*
* @return a boolean
.
*/
boolean isPersistent(T object);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy