EscapeClassifier.java

99 lines | 2.971 kB Blame History Raw Download
//----------------------------------------------------------------------------
// Copyright (C) 2011  Ingrid Nunes
// 
// This library 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 2.1 of the License, or (at your option) any later version.
// 
// This library 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 this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
// 
// To contact the authors:
// http://inf.ufrgs.br/prosoft/bdi4jade/
//
//----------------------------------------------------------------------------
package br.ufrgs.inf.bdinetr.domain.escape;

import java.util.HashSet;
import java.util.Iterator;
import java.util.Observable;
import java.util.Observer;
import java.util.Set;

import br.ufrgs.inf.bdinetr.domain.Classifier;
import br.ufrgs.inf.bdinetr.domain.Flow;
import br.ufrgs.inf.bdinetr.domain.Ip;
import br.ufrgs.inf.bdinetr.domain.Router;
import br.ufrgs.inf.bdinetr.domain.omnet.event.ThreatEvent;

/**
 * @author Alberto Egon and Ingrid Nunes
 */
public class EscapeClassifier extends EscapeRouterComponent implements
		Classifier, Observer {

	private static final long WAITING_TIME = 20000;

	private final Set<ThreatEvent> events;

	public EscapeClassifier(Router router) {
		super(router);
		this.events = new HashSet<>();
		EventBroker.getInstance().addObserver(this);
	}

	@Override
	public Set<Flow> classifyFlows(Ip ip) {
		synchronized (events) {
			Set<Flow> flows = new HashSet<>();
			
			long begin = System.currentTimeMillis();
			long elapsed = System.currentTimeMillis() - begin;
			
			while (events.isEmpty() || (elapsed < WAITING_TIME)) {
				try {
					log.info("Elapsed time: " + elapsed + " - Events empty: "
							+ events.isEmpty());
					long timeout = (WAITING_TIME - elapsed) < 0 ? 0
							: WAITING_TIME - elapsed;
					events.wait(timeout);
					elapsed = System.currentTimeMillis() - begin;
				} catch (InterruptedException e) {
					log.warn(e);
				}
			}
			
			log.info("Finished receiving Threat events. Elapsed time: "
					+ elapsed + " got " + events.size() + " messages.");

			Iterator<ThreatEvent> it = events.iterator();
			
			while (it.hasNext()) {
				ThreatEvent event = it.next();
				flows.add(event.getFlow());
				it.remove();
			}
			
			return flows;
		}
	}

	@Override
	public synchronized void update(Observable o, Object arg) {
		if (arg instanceof ThreatEvent) {
			synchronized (events) {
				events.add((ThreatEvent) arg);
				events.notifyAll();
			}
		}
	}

}