/**
* Copyright (c) 2009--2014 Red Hat, Inc.
*
* This software is licensed to you under the GNU General Public License,
* version 2 (GPLv2). There is NO WARRANTY for this software, express or
* implied, including the implied warranties of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. You should have received a copy of GPLv2
* along with this software; if not, see
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
*
* Red Hat trademarks are not licensed under GPLv2. No permission is
* granted to use or replicate Red Hat trademarks that are incorporated
* in this software or its documentation.
*/
package com.redhat.rhn.taskomatic.task.repomd;
import com.redhat.rhn.common.conf.ConfigDefaults;
import com.redhat.rhn.common.db.datasource.ModeFactory;
import com.redhat.rhn.common.db.datasource.SelectMode;
import com.redhat.rhn.common.db.datasource.WriteMode;
import com.redhat.rhn.common.hibernate.HibernateFactory;
import com.redhat.rhn.taskomatic.task.TaskConstants;
import com.redhat.rhn.taskomatic.task.threaded.QueueDriver;
import com.redhat.rhn.taskomatic.task.threaded.QueueWorker;
import org.apache.log4j.Logger;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
/**
*
* @version $Rev $
*
*/
public class ChannelRepodataDriver implements QueueDriver {
private Logger logger = null;
/**
* {@inheritDoc}
*/
public void initialize() {
WriteMode resetChannelRepodata = ModeFactory.getWriteMode(TaskConstants.MODE_NAME,
TaskConstants.TASK_QUERY_REPOMOD_CLEAR_IN_PROGRESS);
try {
int eqReset = resetChannelRepodata.executeUpdate(new HashMap());
if (eqReset > 0) {
logger.info("Resetting " + eqReset + " unfinished channel repodata tasks");
}
HibernateFactory.commitTransaction();
}
catch (Exception e) {
logger.error("Error resetting rhnRepoRegenQueue.next_action", e);
HibernateFactory.rollbackTransaction();
}
finally {
HibernateFactory.closeSession();
}
}
/**
* @return Returns boolean canContinue
*/
public boolean canContinue() {
return true;
}
/**
* @return Returns candidates
*/
public List getCandidates() {
SelectMode select = ModeFactory.getMode(TaskConstants.MODE_NAME,
TaskConstants.TASK_QUERY_REPOMD_DRIVER_QUERY);
Map<String, Object> params = new HashMap<String, Object>();
List<Object> retval = new LinkedList<Object>();
List results = select.execute(params);
if (results != null) {
for (Iterator iter = results.iterator(); iter.hasNext();) {
retval.add(iter.next());
}
}
return retval;
}
/**
* @return Returns Logger
*/
public Logger getLogger() {
return logger;
}
/**
* {@inheritDoc}
*/
public void setLogger(Logger loggerIn) {
logger = loggerIn;
}
/**
* @return Returns max workers
*/
public int getMaxWorkers() {
return ConfigDefaults.get().getTaskoChannelRepodataWorkers();
}
/**
* @param workItem work item
* @return Returns channel repodata worker object
*/
public QueueWorker makeWorker(Object workItem) {
return new ChannelRepodataWorker((Map) workItem, getLogger());
}
}