/******************************************************************************* * This file is part of OpenNMS(R). * * Copyright (C) 2008-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.provision.support; import org.apache.mina.core.service.IoHandlerAdapter; import org.apache.mina.core.session.IdleStatus; import org.apache.mina.core.session.IoSession; import org.opennms.core.utils.LogUtils; /** * <p>BaseDetectorHandler class.</p> * * @author Donald Desloge * @version $Id: $ */ public class BaseDetectorHandler<Request, Response> extends IoHandlerAdapter { private DetectFutureMinaImpl m_future; private AsyncClientConversation<Request, Response> m_conversation; /** * <p>setFuture</p> * * @param future a {@link org.opennms.netmgt.provision.DetectFuture} object. * @param <Request> a Request object. * @param <Response> a Response object. */ public void setFuture(DetectFutureMinaImpl future) { m_future = future; } /** * <p>getFuture</p> * * @return a {@link org.opennms.netmgt.provision.DetectFuture} object. */ public DetectFutureMinaImpl getFuture() { return m_future; } /** {@inheritDoc} */ @Override public void sessionCreated(IoSession session) throws Exception { } /** {@inheritDoc} */ @Override public void sessionOpened(IoSession session) throws Exception { if(!getConversation().hasBanner() && getConversation().getRequest() != null) { Object request = getConversation().getRequest(); session.write(request); } } /** {@inheritDoc} */ @Override public void sessionClosed(IoSession session) throws Exception { if(!getFuture().isDone()) { LogUtils.infof(this, "Session closed and detection is not complete. Setting service detection to false."); getFuture().setServiceDetected(false); } } /** {@inheritDoc} */ @Override public void sessionIdle(IoSession session, IdleStatus status) throws Exception { if(getConversation().hasBanner() && status == IdleStatus.READER_IDLE) { LogUtils.infof(this, "Session went idle without receiving banner. Setting service detection to false."); getFuture().setServiceDetected(false); session.close(true); } } /** {@inheritDoc} */ @Override public void exceptionCaught(IoSession session, Throwable cause) throws Exception { LogUtils.debugf(this, cause, "Caught a Throwable in BaseDetectorHandler"); getFuture().setException(cause); session.close(true); } /** {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public void messageReceived(IoSession session, Object message) throws Exception { try { LogUtils.debugf(this, "Client Receiving: %s", message.toString().trim()); if(getConversation().hasExchanges() && getConversation().validate((Response)message)) { Object request = getConversation().getRequest(); if(request != null) { session.write(request); }else if(request == null && getConversation().isComplete()){ LogUtils.infof(this, "Conversation is complete and there are no more pending requests. Setting service detection to true."); getFuture().setServiceDetected(true); session.close(false); }else { LogUtils.infof(this, "Conversation is incomplete. Setting service detection to false."); getFuture().setServiceDetected(false); session.close(false); } }else { LogUtils.infof(this, "Conversation response was invalid. Setting service detection to false."); getFuture().setServiceDetected(false); session.close(false); } }catch(Throwable e){ if(!session.isClosing()){ session.close(true); } } } /** * <p>setConversation</p> * * @param conversation a {@link org.opennms.netmgt.provision.support.AsyncClientConversation} object. */ public void setConversation(AsyncClientConversation<Request, Response> conversation) { m_conversation = conversation; } /** * <p>getConversation</p> * * @return a {@link org.opennms.netmgt.provision.support.AsyncClientConversation} object. */ public AsyncClientConversation<Request, Response> getConversation() { return m_conversation; } }