2014-02-17 23:58:40 +01:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Copyright 2003-2006 Jive Software.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2014-08-20 00:25:57 +02:00
|
|
|
package org.jivesoftware.smackx.jingleold.listeners;
|
2014-02-17 23:58:40 +01:00
|
|
|
|
2014-03-19 14:22:20 +01:00
|
|
|
import org.jivesoftware.smack.SmackException.NotConnectedException;
|
2014-02-17 23:58:40 +01:00
|
|
|
import org.jivesoftware.smack.XMPPException;
|
2014-08-20 00:25:57 +02:00
|
|
|
import org.jivesoftware.smackx.jingleold.JingleSession;
|
|
|
|
import org.jivesoftware.smackx.jingleold.media.PayloadType;
|
|
|
|
import org.jivesoftware.smackx.jingleold.nat.TransportCandidate;
|
2014-02-17 23:58:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface for listening for session events.
|
|
|
|
* @author Thiago Camargo
|
|
|
|
*/
|
|
|
|
public interface JingleSessionListener extends JingleListener {
|
|
|
|
/**
|
|
|
|
* Notification that the session has been established. Arguments specify
|
|
|
|
* the payload type and transport to use.
|
|
|
|
*
|
|
|
|
* @param pt the Payload tyep to use
|
|
|
|
* @param remoteCandidate the remote candidate to use for connecting to the remote
|
|
|
|
* service.
|
|
|
|
* @param localCandidate the local candidate where we must listen for connections
|
|
|
|
* @param jingleSession Session that called the method
|
2014-03-19 14:22:20 +01:00
|
|
|
* @throws NotConnectedException
|
2014-02-17 23:58:40 +01:00
|
|
|
*/
|
|
|
|
public void sessionEstablished(PayloadType pt, TransportCandidate remoteCandidate,
|
2014-03-19 14:22:20 +01:00
|
|
|
TransportCandidate localCandidate, JingleSession jingleSession) throws NotConnectedException;
|
2014-02-17 23:58:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Notification that the session was declined.
|
|
|
|
*
|
|
|
|
* @param reason the reason (if any).
|
|
|
|
* @param jingleSession Session that called the method
|
|
|
|
*/
|
|
|
|
public void sessionDeclined(String reason, JingleSession jingleSession);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notification that the session was redirected.
|
|
|
|
*
|
|
|
|
* @param redirection
|
|
|
|
* @param jingleSession session that called the method
|
|
|
|
*/
|
|
|
|
public void sessionRedirected(String redirection, JingleSession jingleSession);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notification that the session was closed normally.
|
|
|
|
*
|
|
|
|
* @param reason the reason (if any).
|
|
|
|
* @param jingleSession Session that called the method
|
|
|
|
*/
|
|
|
|
public void sessionClosed(String reason, JingleSession jingleSession);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notification that the session was closed due to an exception.
|
|
|
|
*
|
|
|
|
* @param e the exception.
|
|
|
|
* @param jingleSession session that called the method
|
|
|
|
*/
|
|
|
|
public void sessionClosedOnError(XMPPException e, JingleSession jingleSession);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notification that the Media has arrived for this session.
|
|
|
|
*
|
|
|
|
* @param jingleSession session that called the method
|
|
|
|
* @param participant description of the participant
|
|
|
|
*/
|
|
|
|
public void sessionMediaReceived(JingleSession jingleSession, String participant);
|
|
|
|
|
|
|
|
}
|