/*******************************************************************************
* Australian National University Data Commons
* Copyright (C) 2013 The Australian National University
*
* This file is part of Australian National University Data Commons.
*
* Australian National University Data Commons is free software: you
* can redistribute it and/or modify it under the terms of the GNU
* General Public License as published by the Free Software Foundation,
* either version 3 of the License, or (at your option) any later
* version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
******************************************************************************/
package au.edu.anu.datacommons.doi.logging;
import java.io.Closeable;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import au.edu.anu.datacommons.data.db.PersistenceManager;
import au.edu.anu.datacommons.data.db.dao.DaoException;
/**
* DAO object for responsible for persisting {@link ExtWebResourceLog} instances.
*
* @author Rahul Khanna
*
*/
public class ExtWebResourceLogDao implements Closeable {
private static final Logger LOGGER = LoggerFactory.getLogger(ExtWebResourceLogDao.class);
protected EntityManager entityManager;
public ExtWebResourceLogDao() {
this.entityManager = PersistenceManager.getEntityManagerFactory().createEntityManager();
}
@Override
public void close() {
if (this.entityManager != null)
this.entityManager.close();
}
/**
* Persists an instance of {@link ExtWebResourceLog}
*
* @param log
* Log instance to persist
* @throws DaoException
* when unable to persist
*/
public void create(ExtWebResourceLog log) throws DaoException {
EntityTransaction et = null;
try {
et = this.entityManager.getTransaction();
et.begin();
this.entityManager.persist(log);
et.commit();
} catch (Exception e) {
try {
if (et != null)
et.rollback();
} catch (Exception e1) {
LOGGER.warn(e1.getMessage(), e1);
}
throw new DaoException(e);
}
}
/**
* Updates a previously persisted instance of {@link ExtWebResourceLog}, with the response received from the
* external web service.
*
* @param log
* Log instance to persist
* @return Updated log object
* @throws DaoException
* when unable to persist
*/
public ExtWebResourceLog update(ExtWebResourceLog log) throws DaoException {
EntityTransaction et = null;
try {
et = this.entityManager.getTransaction();
et.begin();
log = this.entityManager.merge(log);
et.commit();
} catch (Exception e) {
try {
if (et != null)
et.rollback();
} catch (Exception e1) {
LOGGER.warn(e1.getMessage(), e1);
}
throw new DaoException(e);
}
return log;
}
}