/* * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.protocol.pcep.impl; import com.google.common.collect.Lists; import java.util.List; import org.opendaylight.protocol.pcep.PCEPSession; import org.opendaylight.protocol.pcep.PCEPSessionListener; import org.opendaylight.protocol.pcep.PCEPTerminationReason; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev181109.Message; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * Simple Session Listener that is notified about messages and changes in the session. */ public class SimpleSessionListener implements PCEPSessionListener { public final List messages = Lists.newArrayList(); public boolean up = false; private static final Logger LOG = LoggerFactory.getLogger(SimpleSessionListener.class); public SimpleSessionListener() { } @Override public void onMessage(final PCEPSession session, final Message message) { LOG.debug("Received message: {} {}", message.getClass(), message); this.messages.add(message); } @Override public synchronized void onSessionUp(final PCEPSession session) { LOG.debug("Session up."); this.up = true; this.notifyAll(); } @Override public void onSessionDown(final PCEPSession session, final Exception exception) { LOG.debug("Session down.", exception); this.up = false; // this.notifyAll(); } @Override public void onSessionTerminated(final PCEPSession session, final PCEPTerminationReason cause) { LOG.debug("Session terminated. Cause : {}", cause.toString()); this.up = false; } }