/*
* Jitsi, the OpenSource Java VoIP and Instant Messaging client.
*
* 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 net.java.sip.communicator.impl.protocol.jabber.extensions.jitsimeet;
import net.java.sip.communicator.impl.protocol.jabber.extensions.*;
import org.jivesoftware.smack.provider.*;
/**
* Packet extension used by Jitsi Meet to advertise local media SSRCs in MUC
* presence.
*
* @author Pawel Domas
*/
public class MediaPresenceExtension
extends AbstractPacketExtension
{
/**
* The namespace of this packet extension.
*/
public static final String NAMESPACE = "http://estos.de/ns/mjs";
/**
* XML element name of this packet extension.
*/
public static final String ELEMENT_NAME = "media";
/**
* Creates an <tt>MediaPresenceExtension</tt> instance.
*
*/
public MediaPresenceExtension()
{
super(NAMESPACE, ELEMENT_NAME);
}
/**
* Registers packet Jitsi Meet media presence packet extensions in given
* <tt>providerManager</tt>.
*
* @param providerManager the <tt>ProviderManager</tt> to which media
* presence extensions will be registered to.
*/
public static void registerExtensions(ProviderManager providerManager)
{
// <media>
providerManager.addExtensionProvider(
MediaPresenceExtension.ELEMENT_NAME,
MediaPresenceExtension.NAMESPACE,
new DefaultPacketExtensionProvider<MediaPresenceExtension>(
MediaPresenceExtension.class));
// <source>
providerManager.addExtensionProvider(
MediaPresenceExtension.Source.ELEMENT_NAME,
MediaPresenceExtension.Source.NAMESPACE,
new DefaultPacketExtensionProvider<Source>(
Source.class));
}
/**
* Source extension element that specifies into about media SSRC.
*/
public static class Source
extends AbstractPacketExtension
{
/**
* Source XML element name.
*/
public final static String ELEMENT_NAME = "source";
/**
* No namespace attached.
*/
public final static String NAMESPACE = "";
/**
* SSRC media type attribute name. Can be 'audio' or 'video'.
*/
public final static String MEDIA_TYPE_ATTR_NAME = "type";
/**
* SSRC number attribute name.
*/
public final static String SOURCE_ATTR_NAME = "ssrc";
/**
* Media direction as used in SDP('sendrecv', 'recvonly', 'sendonly').
*/
public final static String DIRECTION_ATTR_NAME = "direction";
/**
* Creates new instance of <tt>Source</tt> packet extension with default
* 'sendrecv' direction set.
*/
public Source()
{
super(NAMESPACE, ELEMENT_NAME);
// Default direction
setDirection("sendrecv");
}
/**
* Returns media direction
* (values like used in SDP 'sendrecv', 'recvonly'...).
*/
public String getDirection()
{
return getAttributeAsString(DIRECTION_ATTR_NAME);
}
/**
* Returns media synchronization source identifier.
*/
public String getSSRC()
{
return getAttributeAsString(SOURCE_ATTR_NAME);
}
/**
* Sets media type of the media represented by this source packet
* extensions.
* @param mediaType media type string('audio' or 'video').
*/
public void setMediaType(String mediaType)
{
setAttribute(MEDIA_TYPE_ATTR_NAME, mediaType);
}
/**
* Direction of the media represented by this source packet extension.
* @param direction media direction like used in SDP
* ('sendrecv, 'recvonly'...).
*/
public void setDirection(String direction)
{
setAttribute(DIRECTION_ATTR_NAME, direction);
}
/**
* Sets synchronization source identifier of the media represented by
* this source packet extension.
* @param ssrc synchronization source identifier to set.
*/
public void setSSRC(String ssrc)
{
setAttribute(SOURCE_ATTR_NAME, ssrc);
}
/**
* @return type of the media(audio or video) represented by this source
* packet extension.
*/
public String getMediaType()
{
return getAttributeAsString(MEDIA_TYPE_ATTR_NAME);
}
}
}