com.algoTrader.entity.TransactionDaoBase.java Source code

Java tutorial

Introduction

Here is the source code for com.algoTrader.entity.TransactionDaoBase.java

Source

// license-header java merge-point
//
// Attention: Generated code! Do not modify by hand!
// Generated by: hibernate/SpringHibernateDaoBase.vsl in andromda-spring-cartridge.
//
package com.algoTrader.entity;

import com.algoTrader.PrincipalStore;
import com.algoTrader.PropertySearch;
import com.algoTrader.Search;
import com.algoTrader.enumeration.Currency;
import com.algoTrader.enumeration.TransactionType;
import java.math.BigDecimal;
import java.security.Principal;
import java.util.Collection;
import java.util.Date;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;
import org.andromda.spring.PaginationResult;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.collections.Transformer;
import org.hibernate.Criteria;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.ScrollableResults;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

/**
 * <p>
 * Base Spring DAO Class: is able to create, update, remove, load, and find
 * objects of type <code>Transaction</code>.
 * </p>
 *
 * @see Transaction
 */
public abstract class TransactionDaoBase extends HibernateDaoSupport implements TransactionDao {
    /**
     * {@inheritDoc}
     */
    @Override
    public Object get(final int transform, final int id) {
        final Object entity = this.getHibernateTemplate().get(TransactionImpl.class, new Integer(id));
        return transformEntity(transform, (Transaction) entity);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Transaction get(int id) {
        return (Transaction) this.get(TRANSFORM_NONE, id);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Object load(final int transform, final int id) {
        final Object entity = this.getHibernateTemplate().get(TransactionImpl.class, new Integer(id));
        return transformEntity(transform, (Transaction) entity);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Transaction load(int id) {
        return (Transaction) this.load(TRANSFORM_NONE, id);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public Collection<Transaction> loadAll() {
        return (Collection<Transaction>) this.loadAll(TransactionDao.TRANSFORM_NONE);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Collection<?> loadAll(final int transform) {
        return this.loadAll(transform, -1, -1);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Collection<?> loadAll(final int pageNumber, final int pageSize) {
        return this.loadAll(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Collection<?> loadAll(final int transform, final int pageNumber, final int pageSize) {
        try {
            final Criteria criteria = this.getSession(false).createCriteria(TransactionImpl.class);
            if (pageNumber > 0 && pageSize > 0) {
                criteria.setFirstResult(this.calculateFirstResult(pageNumber, pageSize));
                criteria.setMaxResults(pageSize);
            }
            final Collection<?> results = criteria.list();
            this.transformEntities(transform, results);
            return results;
        } catch (HibernateException ex) {
            throw super.convertHibernateAccessException(ex);
        }
    }

    /**
     * firstResult = (pageNumber - 1) * pageSize
     * @param pageNumber
     * @param pageSize
     * @return firstResult
     */
    protected int calculateFirstResult(int pageNumber, int pageSize) {
        int firstResult = 0;
        if (pageNumber > 0) {
            firstResult = (pageNumber - 1) * pageSize;
        }
        return firstResult;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Transaction create(Transaction transaction) {
        return (Transaction) this.create(TransactionDao.TRANSFORM_NONE, transaction);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Object create(final int transform, final Transaction transaction) {
        if (transaction == null) {
            throw new IllegalArgumentException("Transaction.create - 'transaction' can not be null");
        }
        this.getHibernateTemplate().save(transaction);
        return this.transformEntity(transform, transaction);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public Collection<Transaction> create(final Collection<Transaction> entities) {
        return (Collection<Transaction>) create(TransactionDao.TRANSFORM_NONE, entities);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Collection<?> create(final int transform, final Collection<Transaction> entities) {
        if (entities == null) {
            throw new IllegalArgumentException("Transaction.create - 'entities' can not be null");
        }
        this.getHibernateTemplate().executeWithNativeSession(new HibernateCallback() {
            public Object doInHibernate(Session session) throws HibernateException {
                for (Transaction entity : entities) {
                    create(transform, entity);
                }
                return null;
            }
        });
        return entities;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Transaction create(Date dateTime, long quantity, BigDecimal price, BigDecimal commission,
            Currency currency, TransactionType type) {
        return (Transaction) this.create(TransactionDao.TRANSFORM_NONE, dateTime, quantity, price, commission,
                currency, type);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Object create(final int transform, Date dateTime, long quantity, BigDecimal price, BigDecimal commission,
            Currency currency, TransactionType type) {
        Transaction entity = new TransactionImpl();
        entity.setDateTime(dateTime);
        entity.setQuantity(quantity);
        entity.setPrice(price);
        entity.setCommission(commission);
        entity.setCurrency(currency);
        entity.setType(type);
        return this.create(transform, entity);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public void update(Transaction transaction) {
        if (transaction == null) {
            throw new IllegalArgumentException("Transaction.update - 'transaction' can not be null");
        }
        this.getHibernateTemplate().update(transaction);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public void update(final Collection<Transaction> entities) {
        if (entities == null) {
            throw new IllegalArgumentException("Transaction.update - 'entities' can not be null");
        }
        this.getHibernateTemplate().executeWithNativeSession(new HibernateCallback() {
            public Object doInHibernate(Session session) throws HibernateException {
                for (Transaction entity : entities) {
                    update(entity);
                }
                return null;
            }
        });
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public void remove(Transaction transaction) {
        if (transaction == null) {
            throw new IllegalArgumentException("Transaction.remove - 'transaction' can not be null");
        }
        this.getHibernateTemplate().delete(transaction);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public void remove(int id) {
        Transaction entity = this.get(id);
        if (entity != null) {
            this.remove(entity);
        }
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public void remove(Collection<Transaction> entities) {
        if (entities == null) {
            throw new IllegalArgumentException("Transaction.remove - 'entities' can not be null");
        }
        this.getHibernateTemplate().deleteAll(entities);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllTrades() {
        return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List<?> findAllTrades(final int transform) {
        return this.findAllTrades(transform, -1, -1);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllTrades(final String queryString) {
        return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE, queryString);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllTrades(final int pageNumber, final int pageSize) {
        return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllTrades(final String queryString, final int pageNumber, final int pageSize) {
        return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE, queryString, pageNumber,
                pageSize);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List<?> findAllTrades(final int transform, final String queryString) {
        return this.findAllTrades(transform, queryString, -1, -1);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List<?> findAllTrades(final int transform, final int pageNumber, final int pageSize) {
        return this.findAllTrades(transform,
                "from TransactionImpl as t join fetch t.security where t.type = 'BUY' or t.type = 'SELL' or t.type = 'EXPIRATION' order by t.id",
                pageNumber, pageSize);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings("unchecked")
    public List<?> findAllTrades(final int transform, final String queryString, int pageNumber, int pageSize) {
        try {
            Query queryObject = super.getSession(false).createQuery(queryString);
            queryObject.setCacheable(true);
            if (pageNumber > 0 && pageSize > 0) {
                queryObject.setFirstResult(this.calculateFirstResult(pageNumber, pageSize));
                queryObject.setMaxResults(pageSize);
            }
            List results = queryObject.list();
            transformEntities(transform, results);
            return results;
        } catch (HibernateException ex) {
            throw super.convertHibernateAccessException(ex);
        }
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllCashflows() {
        return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List<?> findAllCashflows(final int transform) {
        return this.findAllCashflows(transform, -1, -1);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllCashflows(final String queryString) {
        return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE, queryString);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllCashflows(final int pageNumber, final int pageSize) {
        return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public List<Transaction> findAllCashflows(final String queryString, final int pageNumber, final int pageSize) {
        return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE, queryString, pageNumber,
                pageSize);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List<?> findAllCashflows(final int transform, final String queryString) {
        return this.findAllCashflows(transform, queryString, -1, -1);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List<?> findAllCashflows(final int transform, final int pageNumber, final int pageSize) {
        return this.findAllCashflows(transform,
                "from TransactionImpl as t where t.type = 'CREDIT' or t.type = 'DEBIT' or t.type = 'INTREST' or t.type = 'FEES' order by t.id",
                pageNumber, pageSize);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings("unchecked")
    public List<?> findAllCashflows(final int transform, final String queryString, int pageNumber, int pageSize) {
        try {
            Query queryObject = super.getSession(false).createQuery(queryString);
            queryObject.setCacheable(true);
            if (pageNumber > 0 && pageSize > 0) {
                queryObject.setFirstResult(this.calculateFirstResult(pageNumber, pageSize));
                queryObject.setMaxResults(pageSize);
            }
            List results = queryObject.list();
            transformEntities(transform, results);
            return results;
        } catch (HibernateException ex) {
            throw super.convertHibernateAccessException(ex);
        }
    }

    /**
     * Allows transformation of entities into value objects
     * (or something else for that matter), when the <code>transform</code>
     * flag is set to one of the constants defined in <code>TransactionDao</code>, 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 TransactionDao}
     * @param entity an entity that was found
     * @return the transformed entity (i.e. new value object, etc)
     * @see TransactionDao#transformEntity(int, Transaction)
     */
    public Object transformEntity(final int transform, final Transaction entity) {
        Object target = null;
        if (entity != null) {
            switch (transform) {
            case TransactionDao.TRANSFORM_NONE: // fall-through
            default:
                target = entity;
            }
        }
        return target;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public void transformEntities(final int transform, final Collection<?> entities) {
        switch (transform) {
        case TransactionDao.TRANSFORM_NONE: // fall-through
        default:
            // do nothing;
        }
    }

    /**
     * @see TransactionDao#toEntities(Collection)
     */
    public void toEntities(final Collection<?> results) {
        if (results != null) {
            CollectionUtils.transform(results, this.ENTITYTRANSFORMER);
        }
    }

    /**
     * This anonymous transformer is designed to transform report query results
     * (which result in an array of entities) to {@link Transaction}
     * using the Jakarta Commons-Collections Transformation API.
     */
    private Transformer ENTITYTRANSFORMER = new Transformer() {
        public Object transform(Object input) {
            Object result = null;
            if (input instanceof Object[]) {
                result = toEntity((Object[]) input);
            } else if (input instanceof Transaction) {
                result = input;
            }
            return result;
        }
    };

    /**
     * @param row
     * @return Transaction
     */
    protected Transaction toEntity(Object[] row) {
        Transaction target = null;
        if (row != null) {
            final int numberOfObjects = row.length;
            for (int ctr = 0; ctr < numberOfObjects; ctr++) {
                final Object object = row[ctr];
                if (object instanceof Transaction) {
                    target = (Transaction) object;
                    break;
                }
            }
        }
        return target;
    }

    /**
     * Gets the current <code>principal</code> if one has been set,
     * otherwise returns <code>null</code>.
     *
     * @return the current principal
     */
    protected Principal getPrincipal() {
        return PrincipalStore.get();
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings({ "unchecked" })
    public PaginationResult search(final int transform, final int pageNumber, final int pageSize,
            final Search search) {
        try {
            search.setPageNumber(pageNumber);
            search.setPageSize(pageSize);
            final PropertySearch propertySearch = new PropertySearch(this.getSession(false), TransactionImpl.class,
                    search);
            final List results = propertySearch.executeAsList();
            this.transformEntities(transform, results);
            return new PaginationResult(results.toArray(new Object[results.size()]),
                    propertySearch.getTotalCount());
        } catch (HibernateException ex) {
            throw super.convertHibernateAccessException(ex);
        }
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public PaginationResult search(final int pageNumber, final int pageSize, final Search search) {
        return this.search(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize, search);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Set<?> search(final int transform, final Search search) {
        try {
            final PropertySearch propertySearch = new PropertySearch(this.getSession(false), TransactionImpl.class,
                    search);
            final Set<?> results = propertySearch.executeAsSet();
            this.transformEntities(transform, results);
            return results;
        } catch (HibernateException ex) {
            throw super.convertHibernateAccessException(ex);
        }
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @SuppressWarnings("unchecked")
    public Set<Transaction> search(final Search search) {
        return (Set<Transaction>) this.search(TransactionDao.TRANSFORM_NONE, search);
    }

    /**
     * Executes and returns the given Hibernate queryObject as a {@link PaginationResult} instance.
     * @param queryObject
     * @param transform
     * @param pageNumber
     * @param pageSize
     * @return PaginationResult
     */
    @SuppressWarnings({ "unchecked" })
    protected PaginationResult getPaginationResult(final Query queryObject, final int transform, int pageNumber,
            int pageSize) {
        try {
            final ScrollableResults scrollableResults = queryObject.scroll();
            scrollableResults.last();
            int totalCount = scrollableResults.getRowNumber();
            totalCount = totalCount >= 0 ? totalCount + 1 : 0;
            if (pageNumber > 0 && pageSize > 0) {
                queryObject.setFirstResult(this.calculateFirstResult(pageNumber, pageSize));
                queryObject.setMaxResults(pageSize);
            }
            // Unchecked transformation because Set object is reused, cannot be strongly typed.
            Set results = new LinkedHashSet(queryObject.list());
            transformEntities(transform, results);
            return new PaginationResult(results.toArray(new Object[results.size()]), totalCount);
        } catch (HibernateException ex) {
            throw super.convertHibernateAccessException(ex);
        }
    }

    // spring-hibernate-dao-base merge-point
}