All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jitsi.impl.neomedia.RTCPConnectorInputStream Maven / Gradle / Ivy

/*
 * Copyright @ 2015 Atlassian Pty Ltd
 *
 * 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.
 */
package org.jitsi.impl.neomedia;

import java.io.*;
import java.net.*;
import java.util.*;

import javax.media.*;

import org.jitsi.service.neomedia.event.*;

/**
 *
 * @author Bing SU ([email protected])
 * @author Lyubomir Marinov
 * @author Sebastien Vincent
 */
public class RTCPConnectorInputStream
    extends RTPConnectorUDPInputStream
{
    /**
     * List of RTCP feedback message listeners;
     */
    private final List listeners
        = new ArrayList();

    /**
     * Initializes a new RTCPConnectorInputStream which is to receive
     * packet data from a specific UDP socket.
     *
     * @param socket the UDP socket the new instance is to receive data from
     */
    public RTCPConnectorInputStream(DatagramSocket socket)
    {
        super(socket);
    }

    /**
     * Add an RTCPFeedbackMessageListener.
     *
     * @param listener object that will listen to incoming RTCP feedback
     * messages.
     */
    public void addRTCPFeedbackMessageListener(
            RTCPFeedbackMessageListener listener)
    {
        if (listener == null)
            throw new NullPointerException("listener");
        if(!listeners.contains(listener))
            listeners.add(listener);
    }

    /**
     * Notifies a specific list of RTCPFeedbackMessageListeners about a
     * specific RTCP feedback message if such a message can be parsed out of a
     * specific byte buffer.
     *
     * @param source the object to be reported as the source of the
     * RTCPFeedbackMessageEvent to be fired
     * @param buffer the byte buffer which may specific an RTCP
     * feedback message
     * @param offset the offset in buffer at which the reading of bytes
     * is to begin
     * @param length the number of bytes in buffer to be read for the
     * purposes of parsing an RTCP feedback message and firing an
     * RTPCFeedbackEvent
     * @param listeners the list of RTCPFeedbackMessageListeners to be
     * notified about the specified RTCP feedback message if such a message can
     * be parsed out of the specified buffer
     */
    public static void fireRTCPFeedbackMessageReceived(
            Object source,
            byte[] buffer, int offset, int length,
            List listeners)
    {
        /*
         * RTCP feedback message length is minimum 12 bytes:
         * 1. Version/Padding/Feedback message type: 1 byte
         * 2. Payload type: 1 byte
         * 3. Length: 2 bytes
         * 4. SSRC of packet sender: 4 bytes
         * 5. SSRC of media source: 4 bytes
         */
        if ((length >= 12) && !listeners.isEmpty())
        {
            int pt = buffer[offset + 1] & 0xFF;

            if ((pt == RTCPFeedbackMessageEvent.PT_PS)
                    || (pt == RTCPFeedbackMessageEvent.PT_TL))
            {
                int fmt = buffer[offset] & 0x1F;
                RTCPFeedbackMessageEvent ev
                    = new RTCPFeedbackMessageEvent(source, fmt, pt);

                for (RTCPFeedbackMessageListener l : listeners)
                    l.rtcpFeedbackMessageReceived(ev);
            }
        }
    }

    /**
     * Remove an RTCPFeedbackMessageListener.
     *
     * @param listener object to remove from listening RTCP feedback messages.
     */
    public void removeRTCPFeedbackMessageListener(
            RTCPFeedbackMessageListener listener)
    {
        listeners.remove(listener);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    protected int read(Buffer buffer, byte[] data, int offset, int length)
        throws IOException
    {
        int pktLength = super.read(buffer, data, offset, length);

        fireRTCPFeedbackMessageReceived(
                this,
                data, offset, pktLength,
                listeners);

        return pktLength;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy