/* * JBoss, Home of Professional Open Source * Copyright 2011, Red Hat, Inc. and individual contributors * by the @authors tag. See the copyright.txt in the distribution for a * full listing of individual contributors. * * This 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 software 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 software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.restcomm.media.rtcp; import java.util.ArrayList; import java.util.List; /** * * @author amit bhayani * */ public class RtcpSdes extends RtcpHeader { /** * SDES */ private final List<RtcpSdesChunk> sdesChunks; protected RtcpSdes() { this.sdesChunks = new ArrayList<RtcpSdesChunk>(RtcpPacket.MAX_SOURCES); } public RtcpSdes(boolean padding) { super(padding, RtcpHeader.RTCP_SDES); this.sdesChunks = new ArrayList<RtcpSdesChunk>(RtcpPacket.MAX_SOURCES); } protected int decode(byte[] rawData, int offSet) { int tmp = offSet; offSet = super.decode(rawData, offSet); while ((offSet - tmp) < this.length) { RtcpSdesChunk rtcpSdesChunk = new RtcpSdesChunk(); offSet = rtcpSdesChunk.decode(rawData, offSet); this.sdesChunks.add(rtcpSdesChunk); } return offSet; } protected int encode(byte[] rawData, int offSet) { int startPosition = offSet; offSet = super.encode(rawData, offSet); for (RtcpSdesChunk rtcpSdesChunk : sdesChunks) { if (rtcpSdesChunk != null) { offSet = rtcpSdesChunk.encode(rawData, offSet); } else { break; } } /* Reduce 4 octest of header and length is in terms 32bits word */ this.length = (offSet - startPosition - 4) / 4; rawData[startPosition + 2] = ((byte) ((this.length & 0xFF00) >> 8)); rawData[startPosition + 3] = ((byte) (this.length & 0x00FF)); return offSet; } public void addRtcpSdesChunk(RtcpSdesChunk rtcpSdesChunk) { if(this.count >= RtcpPacket.MAX_SOURCES) { throw new ArrayIndexOutOfBoundsException("Reached maximum number of chunks: "+ RtcpPacket.MAX_SOURCES); } this.sdesChunks.add(rtcpSdesChunk); this.count++; } public RtcpSdesChunk[] getSdesChunks() { RtcpSdesChunk[] chunks = new RtcpSdesChunk[this.sdesChunks.size()]; return this.sdesChunks.toArray(chunks); } public String getCname() { for (RtcpSdesChunk chunk : this.sdesChunks) { String cname = chunk.getCname(); if(cname != null && !cname.isEmpty()) { return cname; } } return ""; } @Override public String toString() { StringBuilder builder = new StringBuilder("SDES:\n"); builder.append("version= ").append(this.version).append(", "); builder.append("padding= ").append(this.padding).append(", "); builder.append("source count= ").append(this.count).append(", "); builder.append("packet type= ").append(this.packetType).append(", "); builder.append("length= ").append(this.length).append(", "); for (RtcpSdesChunk chunk : this.sdesChunks) { builder.append("\n").append(chunk.toString()); } return builder.toString(); } }