Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* MIT License
*
* Copyright (c) 2021-2099 Oscura (xingshuang)
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package com.github.xingshuangs.iot.protocol.rtcp.model;
import com.github.xingshuangs.iot.common.buff.ByteReadBuff;
import com.github.xingshuangs.iot.common.buff.ByteWriteBuff;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.util.ArrayList;
import java.util.List;
/**
* 发送者报告
* 0 1 2 3
* 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* |V=2|P| RC | PT=SR=200 | length |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | SSRC of sender |
* +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
* | NTP timestamp, most significant word |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | NTP timestamp, least significant word |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | RTP timestamp |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | sender's packet count |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | sender's octet count |
* +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
* | SSRC_1 (SSRC of first source) |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | fraction lost | cumulative number of packets lost |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | extended highest sequence number received |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | interarrival jitter |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | last SR (LSR) |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* | delay since last SR (DLSR) |
* +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
* | SSRC_2 (SSRC of second source) |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* : ... :
* +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
* | profile-specific extensions |
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
*
* @author xingshuang
*/
@Data
@EqualsAndHashCode(callSuper = true)
public final class RtcpSenderReport extends RtcpBasePackage {
/**
* Source id.
* 同步源(SSRC of sender):32比特,SR包发送者的同步源标识符。与对应RTP包中的SSRC一样。
*/
private long sourceId;
/**
* Sender info.
* 发送者信息
*/
private RtcpSenderInfo senderInfo;
/**
* Report blocks.
* 报告数据块
*/
private List reportBlocks = new ArrayList<>();
@Override
public int byteArrayLength() {
int length = 0;
length += this.header != null ? this.header.byteArrayLength() : 0;
length += 4;
length += this.senderInfo != null ? this.senderInfo.byteArrayLength() : 0;
for (RtcpReportBlock block : this.reportBlocks) {
length += block.byteArrayLength();
}
return length;
}
@Override
public byte[] toByteArray() {
ByteWriteBuff buff = ByteWriteBuff.newInstance(this.byteArrayLength());
if (this.header != null) {
buff.putBytes(this.header.toByteArray());
}
buff.putInteger(this.sourceId);
if (this.senderInfo != null) {
buff.putBytes(this.senderInfo.toByteArray());
}
for (RtcpReportBlock block : this.reportBlocks) {
buff.putBytes(block.toByteArray());
}
return buff.getData();
}
/**
* Parses byte array and converts it to object.
*
* @param data byte array
* @return RtcpHeader
*/
public static RtcpSenderReport fromBytes(final byte[] data) {
return fromBytes(data, 0);
}
/**
* Parses byte array and converts it to object.
*
* @param data byte array
* @param offset index offset
* @return RtcpHeader
*/
public static RtcpSenderReport fromBytes(final byte[] data, final int offset) {
if (data.length < 28) {
throw new IndexOutOfBoundsException("RtcpSenderReport, data length < 28");
}
int off = offset;
RtcpSenderReport res = new RtcpSenderReport();
res.header = RtcpHeader.fromBytes(data, off);
off += res.header.byteArrayLength();
res.sourceId = ByteReadBuff.newInstance(data, off).getUInt32();
off += 4;
res.senderInfo = RtcpSenderInfo.fromBytes(data, off);
off += res.senderInfo.byteArrayLength();
for (int i = 0; i < res.header.getReceptionCount(); i++) {
RtcpReportBlock reportBlock = RtcpReportBlock.fromBytes(data, off);
res.reportBlocks.add(reportBlock);
off += reportBlock.byteArrayLength();
}
return res;
}
}