/*******************************************************************************
* This file is part of OpenNMS(R).
*
* Copyright (C) 2009-2011 The OpenNMS Group, Inc.
* OpenNMS(R) is Copyright (C) 1999-2011 The OpenNMS Group, Inc.
*
* OpenNMS(R) is a registered trademark of The OpenNMS Group, Inc.
*
* OpenNMS(R) 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.
*
* OpenNMS(R) 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 OpenNMS(R). If not, see:
* http://www.gnu.org/licenses/
*
* For more information contact:
* OpenNMS(R) Licensing <license@opennms.org>
* http://www.opennms.org/
* http://www.opennms.com/
*******************************************************************************/
package org.opennms.netmgt.dao.support;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import org.opennms.core.utils.ThreadCategory;
import org.opennms.netmgt.dao.AcknowledgmentDao;
import org.opennms.netmgt.model.Acknowledgeable;
import org.opennms.netmgt.model.OnmsAcknowledgment;
import org.opennms.netmgt.model.acknowledgments.AckService;
/**
* This class provides the work of acknowledging <code>Acknowledgables</code> associated with
* an <code>Acknowledgment</code>.
*
* @author <a href="mailto:david@opennms.org">David Hustace</a>
* @version $Id: $
*/
public class DefaultAckService implements AckService {
private AcknowledgmentDao m_ackDao;
/** {@inheritDoc} */
public void processAcks(Collection<OnmsAcknowledgment> acks) {
log().info("processAcks: Processing "+acks.size()+" acknowledgements...");
for (OnmsAcknowledgment ack : acks) {
processAck(ack);
}
}
/** {@inheritDoc} */
public void processAck(OnmsAcknowledgment ack) {
log().info("processAck: Searching DB for acknowledgables for ack: "+ack);
List<Acknowledgeable> ackables = m_ackDao.findAcknowledgables(ack);
if (ackables == null || ackables.size() < 1) {
log().debug("processAck: No acknowledgables found.");
throw new IllegalStateException("No acknowlegables in the database for ack: "+ack);
}
log().debug("processAck: Found "+ackables.size()+". Acknowledging...");
Iterator<Acknowledgeable> it = ackables.iterator();
while (it.hasNext()) {
try {
Acknowledgeable ackable = it.next();
switch (ack.getAckAction()) {
case ACKNOWLEDGE:
log().debug("processAck: Acknowledging ackable: "+ackable+"...");
ackable.acknowledge(ack.getAckUser());
log().debug("processAck: Acknowledged ackable: "+ackable);
break;
case UNACKNOWLEDGE:
log().debug("processAck: Unacknowledging ackable: "+ackable+"...");
ackable.unacknowledge(ack.getAckUser());
log().debug("processAck: Unacknowledged ackable: "+ackable);
break;
case CLEAR:
log().debug("processAck: Clearing ackable: "+ackable+"...");
ackable.clear(ack.getAckUser());
log().debug("processAck: Cleared ackable: "+ackable);
break;
case ESCALATE:
log().debug("processAck: Escalating ackable: "+ackable+"...");
ackable.escalate(ack.getAckUser());
log().debug("processAck: Escalated ackable: "+ackable);
break;
default:
break;
}
m_ackDao.updateAckable(ackable);
m_ackDao.save(ack);
m_ackDao.flush();
} catch (Throwable t) {
log().error("processAck: exception while processing: "+ack+"; "+t, t);
}
}
log().info("processAck: Found and processed acknowledgables for the acknowledgement: "+ack);
}
private ThreadCategory log() {
return ThreadCategory.getInstance();
}
/**
* <p>setAckDao</p>
*
* @param ackDao a {@link org.opennms.netmgt.dao.AcknowledgmentDao} object.
*/
public void setAckDao(AcknowledgmentDao ackDao) {
m_ackDao = ackDao;
}
/**
* <p>getAckDao</p>
*
* @return a {@link org.opennms.netmgt.dao.AcknowledgmentDao} object.
*/
public AcknowledgmentDao getAckDao() {
return m_ackDao;
}
}