org.bouncycastle.crypto.tls.TlsSRTPUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcprov-jdk14 Show documentation
Show all versions of bcprov-jdk14 Show documentation
The Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms. This jar contains JCE provider and lightweight API for the Bouncy Castle Cryptography APIs for JDK 1.4.
package org.bouncycastle.crypto.tls;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Hashtable;
import org.bouncycastle.util.Integers;
/**
* RFC 5764 DTLS Extension to Establish Keys for SRTP.
*/
public class TlsSRTPUtils
{
public static final Integer EXT_use_srtp = Integers.valueOf(ExtensionType.use_srtp);
public static void addUseSRTPExtension(Hashtable extensions, UseSRTPData useSRTPData)
throws IOException
{
extensions.put(EXT_use_srtp, createUseSRTPExtension(useSRTPData));
}
public static UseSRTPData getUseSRTPExtension(Hashtable extensions)
throws IOException
{
if (extensions == null)
{
return null;
}
byte[] extensionValue = (byte[])extensions.get(EXT_use_srtp);
if (extensionValue == null)
{
return null;
}
return readUseSRTPExtension(extensionValue);
}
public static byte[] createUseSRTPExtension(UseSRTPData useSRTPData)
throws IOException
{
if (useSRTPData == null)
{
throw new IllegalArgumentException("'useSRTPData' cannot be null");
}
ByteArrayOutputStream buf = new ByteArrayOutputStream();
// SRTPProtectionProfiles
int[] protectionProfiles = useSRTPData.getProtectionProfiles();
TlsUtils.writeUint16(2 * protectionProfiles.length, buf);
TlsUtils.writeUint16Array(protectionProfiles, buf);
// srtp_mki
TlsUtils.writeOpaque8(useSRTPData.getMki(), buf);
return buf.toByteArray();
}
public static UseSRTPData readUseSRTPExtension(byte[] extensionValue)
throws IOException
{
if (extensionValue == null)
{
throw new IllegalArgumentException("'extensionValue' cannot be null");
}
ByteArrayInputStream buf = new ByteArrayInputStream(extensionValue);
// SRTPProtectionProfiles
int length = TlsUtils.readUint16(buf);
if (length < 2 || (length & 1) != 0)
{
throw new TlsFatalAlert(AlertDescription.decode_error);
}
int[] protectionProfiles = TlsUtils.readUint16Array(length / 2, buf);
// srtp_mki
byte[] mki = TlsUtils.readOpaque8(buf);
TlsProtocol.assertEmpty(buf);
return new UseSRTPData(protectionProfiles, mki);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy