org.bouncycastle.tls.ServerName Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bctls-jdk14 Show documentation
Show all versions of bctls-jdk14 Show documentation
The Bouncy Castle Java APIs for TLS and DTLS.
package org.bouncycastle.tls;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import org.bouncycastle.util.Strings;
/**
* RFC 6066 3. Server Name Indication
*
* Current implementation uses this guidance: "For backward compatibility, all future data
* structures associated with new NameTypes MUST begin with a 16-bit length field. TLS MAY treat
* provided server names as opaque data and pass the names and types to the application."
*
* RFC 6066 specifies ASCII encoding for host_name (possibly using A-labels for IDNs), but note that
* the previous version (RFC 4366) specified UTF-8 encoding (see RFC 6066 Appendix A). For maximum
* compatibility, it is recommended that client code tolerate receiving UTF-8 from the peer, but
* only generate ASCII itself.
*/
public final class ServerName
{
private final short nameType;
private final byte[] nameData;
/**
* @deprecated Use {@link #ServerName(short, byte[])} instead.
*/
public ServerName(short nameType, Object name)
{
if (null == name)
{
throw new NullPointerException("'name' cannot be null");
}
byte[] nameData;
switch (nameType)
{
case NameType.host_name:
{
if (name instanceof String)
{
String s = (String)name;
nameData = Strings.toUTF8ByteArray(s);
}
else
{
throw new IllegalArgumentException("'name' is not an instance of a supported type");
}
break;
}
default:
throw new IllegalArgumentException("'nameType' is an unsupported NameType");
}
if (nameData.length < 1 || !TlsUtils.isValidUint16(nameData.length))
{
throw new IllegalArgumentException("'name' must have length from 1 to 65535");
}
this.nameType = nameType;
this.nameData = nameData;
}
public ServerName(short nameType, byte[] nameData)
{
if (!TlsUtils.isValidUint8(nameType))
{
throw new IllegalArgumentException("'nameType' must be from 0 to 255");
}
if (null == nameData)
{
throw new NullPointerException("'nameData' cannot be null");
}
if (nameData.length < 1 || !TlsUtils.isValidUint16(nameData.length))
{
throw new IllegalArgumentException("'nameData' must have length from 1 to 65535");
}
this.nameType = nameType;
this.nameData = nameData;
}
public short getNameType()
{
return nameType;
}
public byte[] getNameData()
{
return nameData;
}
/**
* A convenience method for returning a host_name as a UTF-8 string. Note that this method does
* not attempt to recognize Internationalized Domain Names (see RFC 5890); further processing
* may be required to support them.
*
* @deprecated Use {@link #getNameData()} instead.
*/
public String getHostName()
{
if (NameType.host_name != nameType)
{
throw new IllegalStateException("Not of type host_name");
}
return Strings.fromUTF8ByteArray(nameData);
}
/**
* Encode this {@link ServerName} to an {@link OutputStream}.
*
* @param output
* the {@link OutputStream} to encode to.
* @throws IOException
*/
public void encode(OutputStream output) throws IOException
{
TlsUtils.writeUint8(nameType, output);
TlsUtils.writeOpaque16(nameData, output);
}
/**
* Parse a {@link ServerName} from an {@link InputStream}.
*
* @param input
* the {@link InputStream} to parse from.
* @return a {@link ServerName} object.
* @throws IOException
*/
public static ServerName parse(InputStream input) throws IOException
{
short name_type = TlsUtils.readUint8(input);
byte[] nameData = TlsUtils.readOpaque16(input, 1);
return new ServerName(name_type, nameData);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy