/*
Copyright 2011-2014 Red Hat, Inc
This file is part of PressGang CCMS.
PressGang CCMS 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 3 of the License, or
(at your option) any later version.
PressGang CCMS 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 PressGang CCMS. If not, see <http://www.gnu.org/licenses/>.
*/
package org.jboss.pressgang.ccms.server.utils;
import static com.google.common.base.Strings.isNullOrEmpty;
import javax.persistence.EntityManager;
import javax.transaction.TransactionManager;
import javax.transaction.UserTransaction;
import org.jboss.pressgang.ccms.model.User;
import org.jboss.pressgang.ccms.provider.DBProviderFactory;
import org.jboss.pressgang.ccms.provider.listener.LogMessageListener;
import org.jboss.pressgang.ccms.server.ejb.EnversLoggingBean;
import org.jboss.pressgang.ccms.wrapper.LogMessageWrapper;
public class ProviderUtilities {
public static DBProviderFactory getDBProviderFactory(final EntityManager entityManager, final UserTransaction transactionManager) {
return getDBProviderFactory(entityManager, transactionManager, null);
}
public static DBProviderFactory getDBProviderFactory(final EntityManager entityManager, final UserTransaction transactionManager,
final EnversLoggingBean loggingBean) {
final DBProviderFactory providerFactory = DBProviderFactory.create(entityManager, transactionManager);
if (loggingBean != null) {
final DBLogMessageListener listener = new DBLogMessageListener(entityManager, loggingBean);
providerFactory.registerListener(listener);
}
return providerFactory;
}
public static DBProviderFactory getDBProviderFactory(final EntityManager entityManager) {
return getDBProviderFactory(entityManager, (EnversLoggingBean) null);
}
public static DBProviderFactory getDBProviderFactory(final EntityManager entityManager, final EnversLoggingBean loggingBean) {
final DBProviderFactory providerFactory = DBProviderFactory.create(entityManager);
if (loggingBean != null) {
final DBLogMessageListener listener = new DBLogMessageListener(entityManager, loggingBean);
providerFactory.registerListener(listener);
}
return providerFactory;
}
}
class DBLogMessageListener implements LogMessageListener {
private final EntityManager entityManager;
private final EnversLoggingBean loggingBean;
public DBLogMessageListener(final EntityManager entityManager, final EnversLoggingBean loggingBean) {
this.entityManager = entityManager;
this.loggingBean = loggingBean;
}
@Override
public void handleLogMessage(LogMessageWrapper logMessage) {
if (!isNullOrEmpty(logMessage.getMessage())) {
loggingBean.addLogMessage(logMessage.getMessage());
}
if (logMessage.getFlags() != null) {
loggingBean.setFlag(logMessage.getFlags());
}
if (!isNullOrEmpty(logMessage.getUser())) {
if (logMessage.getUser().matches("^\\d+$")) {
final User user = entityManager.find(User.class, Integer.parseInt(logMessage.getUser()));
loggingBean.setUsername(user.getUserName());
} else {
loggingBean.setUsername(logMessage.getUser());
}
}
}
}