// license-header java merge-point
//
// Attention: Generated code! Do not modify by hand!
// Generated by DaoBase.vsl in andromda-ejb3-cartridge on 09/18/2014 16:56:10.
//
package org.andromda.test.howto9.b;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;
import java.util.List;
import javax.annotation.Resource;
import javax.ejb.Local;
import javax.ejb.SessionContext;
import javax.ejb.TransactionAttribute;
import javax.ejb.TransactionAttributeType;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.TemporalType;
import javax.persistence.TypedQuery;
/**
*
* Base EJB3 DAO Class: is able to create, update, remove, load, and find
* objects of type Person
.
*
*
* @see PersonDao
*/
@TransactionAttribute(TransactionAttributeType.REQUIRED)
@Local({PersonDao.class})
public abstract class PersonDaoBase
implements PersonDao
{
/** Session Context Injection */
@Resource
protected SessionContext context;
/**
* Inject persistence context howtomodel
*/
@PersistenceContext(unitName = "howtomodel")
protected EntityManager emanager;
/**
* @see PersonDao#load
*/
@Override
public Object load(final int transform, final Long id)
throws PersonDaoException
{
if (id == null)
{
throw new IllegalArgumentException(
"Person.load - 'id' can not be null");
}
try
{
final Person entity = this.emanager.find(Person.class, id);
return transformEntity(transform, entity);
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#load( Long)
*/
@Override
public Person load( final Long id)
throws PersonDaoException
{
return (Person)this.load(TRANSFORM_NONE, id);
}
/**
* @see PersonDao#loadAll()
*/
@Override
@SuppressWarnings({"unchecked"})
public Collection loadAll()
throws PersonDaoException
{
return this.loadAll(TRANSFORM_NONE);
}
/**
* @see PersonDao#loadAll(int)
*/
@Override
public Collection loadAll(final int transform)
throws PersonDaoException
{
try
{
TypedQuery query = this.emanager.createNamedQuery("Person.findAll", Person.class);
List results = query.getResultList();
this.transformEntities(transform, results);
return results;
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* Create Person with no VO transformation
* @see PersonDao#create(Person)
*/
@Override
public Person create(Person person)
throws PersonDaoException
{
return (Person)this.create(TRANSFORM_NONE, person);
}
/**
* Create Person with VO transformation
* @see PersonDao#create(int, Person)
*/
@Override
public Object create(final int transform, final Person person)
throws PersonDaoException
{
if (person == null)
{
throw new IllegalArgumentException(
"Person.create - 'person' can not be null");
}
try
{
this.emanager.persist(person);
this.emanager.flush();
return this.transformEntity(transform, person);
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* Create a Collection of Person with no VO transformation
* @see PersonDao#create(Collection)
*/
@Override
@SuppressWarnings({"unchecked"})
public Collection create(final Collection entities)
throws PersonDaoException
{
return create(TRANSFORM_NONE, entities);
}
/**
* Create a Collection of Person with VO transformation
* @see PersonDao#create(int, Collection)
*/
@Override
@SuppressWarnings({"unchecked", "rawtypes"})
public Collection create(final int transform, final Collection entities)
throws PersonDaoException
{
if (entities == null)
{
throw new IllegalArgumentException(
"Person.create - 'entities' can not be null");
}
Collection results = new ArrayList();
try
{
for (final Person entity : entities)
{
results.add(create(transform, entity));
}
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
return results;
}
/**
* Create Entity Person using instance attributes with no VO transformation
* @see PersonDao#create(String, Date)
*/
@Override
public Person create(
String name,
Date birthDate)
throws PersonDaoException
{
return (Person)this.create(TRANSFORM_NONE, name, birthDate);
}
/**
* Create Entity Person using instance attributes with VO transformation
* @see PersonDao#create(int, String, Date)
* composite=false identifiers=1
*/
@Override
public Object create(
final int transform,
String name,
Date birthDate)
throws PersonDaoException
{
Person entity = new Person();
entity.setName(name);
entity.setBirthDate(birthDate);
return this.create(transform, entity);
}
/**
* @see PersonDao#update(Person)
*/
@Override
public void update(Person person)
throws PersonDaoException
{
if (person == null)
{
throw new IllegalArgumentException(
"Person.update - 'person' can not be null");
}
try
{
this.emanager.merge(person);
this.emanager.flush();
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#update(Collection)
*/
@Override
public void update(final Collection entities)
throws PersonDaoException
{
if (entities == null)
{
throw new IllegalArgumentException(
"Person.update - 'entities' can not be null");
}
try
{
for (final Person entity : entities)
{
update(entity);
}
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#remove(Person)
*/
@Override
public void remove(Person person)
throws PersonDaoException
{
if (person == null)
{
throw new IllegalArgumentException(
"Person.remove - 'person' can not be null");
}
try
{
this.emanager.remove(person);
this.emanager.flush();
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#remove(Long)
*/
@Override
public void remove(Long id)
throws PersonDaoException
{
if (id == null)
{
throw new IllegalArgumentException(
"Person.remove - 'id' can not be null");
}
try
{
final Person entity = this.load(id);
if (entity != null)
{
this.remove(entity);
}
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#remove(Collection)
*/
@Override
public void remove(Collection entities)
throws PersonDaoException
{
if (entities == null)
{
throw new IllegalArgumentException(
"Person.remove - 'entities' can not be null");
}
try
{
for (final Person entity : entities)
{
remove(entity);
}
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#findAll()
*/
@Override
public List findAll()
throws PersonDaoException
{
return this.findAll(TRANSFORM_NONE);
}
/**
* @see PersonDao#findAll(String)
*/
@Override
public List findAll(final String queryString)
throws PersonDaoException
{
return this.findAll(TRANSFORM_NONE, queryString);
}
/**
* @see PersonDao#findAll(int)
*/
@Override
public List findAll(final int transform)
throws PersonDaoException
{
try
{
TypedQuery queryObject = this.emanager.createNamedQuery("Person.findAll", Person.class);
List results = queryObject.getResultList();
transformEntities(transform, results);
return results;
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#findAll(int, String)
*/
@Override
public List findAll(final int transform, final String queryString)
throws PersonDaoException
{
try
{
TypedQuery queryObject = this.emanager.createQuery(queryString, Person.class);
List results = queryObject.getResultList();
transformEntities(transform, results);
return results;
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#findByName(String)
*/
@Override
public List findByName(String name)
throws PersonDaoException
{
return this.findByName(TRANSFORM_NONE, name);
}
/**
* @see PersonDao#findByName(String, String)
*/
@Override
public List findByName(final String queryString, final String name)
throws PersonDaoException
{
return this.findByName(TRANSFORM_NONE, queryString, name);
}
/**
* @see PersonDao#findByName(int, String)
*/
@Override
public List findByName(final int transform, final String name)
throws PersonDaoException
{
try
{
TypedQuery queryObject = this.emanager.createNamedQuery("Person.findByName", Person.class);
queryObject.setParameter("name", name);
List results = queryObject.getResultList();
transformEntities(transform, results);
return results;
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#findByName(int, String, String)
*/
@Override
public List findByName(final int transform, final String queryString, final String name)
throws PersonDaoException
{
try
{
TypedQuery queryObject = this.emanager.createQuery(queryString, Person.class);
queryObject.setParameter("name", name);
List results = queryObject.getResultList();
transformEntities(transform, results);
return results;
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#findByNameOrBirthDate(String, Date)
*/
@Override
public List findByNameOrBirthDate(String name, Date birthDate)
throws PersonDaoException
{
return this.findByNameOrBirthDate(TRANSFORM_NONE, name, birthDate);
}
/**
* @see PersonDao#findByNameOrBirthDate(String, String, Date)
*/
@Override
public List findByNameOrBirthDate(final String queryString, final String name, final Date birthDate)
throws PersonDaoException
{
return this.findByNameOrBirthDate(TRANSFORM_NONE, queryString, name, birthDate);
}
/**
* @see PersonDao#findByNameOrBirthDate(int, String, Date)
*/
@Override
public List findByNameOrBirthDate(final int transform, final String name, final Date birthDate)
throws PersonDaoException
{
try
{
TypedQuery queryObject = this.emanager.createNamedQuery("Person.findByNameOrBirthDate", Person.class);
queryObject.setParameter("name", name);
queryObject.setParameter("birthDate", birthDate, TemporalType.DATE);
List results = queryObject.getResultList();
transformEntities(transform, results);
return results;
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* @see PersonDao#findByNameOrBirthDate(int, String, String, Date)
*/
@Override
public List findByNameOrBirthDate(final int transform, final String queryString, final String name, final Date birthDate)
throws PersonDaoException
{
try
{
TypedQuery queryObject = this.emanager.createQuery(queryString, Person.class);
queryObject.setParameter("name", name);
queryObject.setParameter("birthDate", birthDate, TemporalType.DATE);
List results = queryObject.getResultList();
transformEntities(transform, results);
return results;
}
catch (Exception ex)
{
throw new PersonDaoException(ex);
}
}
/**
* Allows transformation of entities into value objects
* (or something else for that matter), when the transform
* flag is set to one of the constants defined in PersonDao
, please note
* that the {@link #TRANSFORM_NONE} constant denotes no transformation, so the entity itself
* will be returned.
*
* If the integer argument value is unknown {@link #TRANSFORM_NONE} is assumed.
*
* @param transform one of the constants declared in {@link PersonDao}
* @param entity an entity that was found
* @return the transformed entity (i.e. new value object, etc)
* @see #transformEntities(int,Collection)
*/
protected Object transformEntity(final int transform, final Person entity)
{
Object target = null;
if (entity != null)
{
switch (transform)
{
case TRANSFORM_NONE : // fall-through
default:
target = entity;
}
}
return target;
}
/**
* Transforms a collection of entities using the
* {@link #transformEntity(int, Person)}
* method. This method does not instantiate a new collection.
*
* Transforms into the same collection as the argument, but this time containing the transformed entities
* This method is to be used internally only.
*
* @param transform one of the constants declared in PersonDao
* @param entities the collection of entities to transform
* @see #transformEntity(int, Person)
*/
protected void transformEntities(final int transform, final Collection entities)
{
switch (transform)
{
case TRANSFORM_NONE : // fall-through
default:
// do nothing;
}
}
// For unit testing outside of container - persistence context not injected
/**
* @return the context
*/
public SessionContext getContext()
{
return this.context;
}
/**
* @param contextIn the context to set
*/
public void setContext(SessionContext contextIn)
{
this.context = contextIn;
}
/**
* @return the emanager
*/
public EntityManager getEmanager()
{
return this.emanager;
}
/**
* @param emanagerIn the emanager to set
*/
public void setEmanager(EntityManager emanagerIn)
{
this.emanager = emanagerIn;
}
}