org.bouncycastle.tls.SignatureAlgorithm Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bctls-fips Show documentation
Show all versions of bctls-fips Show documentation
The Bouncy Castle Java APIs for the TLS, including a JSSE provider. The APIs are designed primarily to be used in conjunction with the BC FIPS provider. The APIs may also be used with other providers although if being used in a FIPS context it is the responsibility of the user to ensure that any other providers used are FIPS certified and used appropriately.
package org.bouncycastle.tls;
/**
* RFC 5246 7.4.1.4.1 (in RFC 2246, there were no specific values assigned)
*/
public class SignatureAlgorithm
{
public static final short anonymous = 0;
public static final short rsa = 1;
public static final short dsa = 2;
public static final short ecdsa = 3;
/*
* RFC 8422
*/
public static final short ed25519 = 7;
public static final short ed448 = 8;
/*
* RFC 8446 (implied from SignatureScheme values)
* RFC 8447 reserved these values without allocating the implied names
*/
public static final short rsa_pss_rsae_sha256 = 4;
public static final short rsa_pss_rsae_sha384 = 5;
public static final short rsa_pss_rsae_sha512 = 6;
public static final short rsa_pss_pss_sha256 = 9;
public static final short rsa_pss_pss_sha384 = 10;
public static final short rsa_pss_pss_sha512 = 11;
/*
* RFC 8734 (implied from SignatureScheme values)
*/
public static final short ecdsa_brainpoolP256r1tls13_sha256 = 26;
public static final short ecdsa_brainpoolP384r1tls13_sha384 = 27;
public static final short ecdsa_brainpoolP512r1tls13_sha512 = 28;
/*
* draft-smyshlyaev-tls12-gost-suites-10
*/
public static final short gostr34102012_256 = 64;
public static final short gostr34102012_512 = 65;
public static short getClientCertificateType(short signatureAlgorithm)
{
switch (signatureAlgorithm)
{
case SignatureAlgorithm.rsa:
case SignatureAlgorithm.rsa_pss_rsae_sha256:
case SignatureAlgorithm.rsa_pss_rsae_sha384:
case SignatureAlgorithm.rsa_pss_rsae_sha512:
case SignatureAlgorithm.rsa_pss_pss_sha256:
case SignatureAlgorithm.rsa_pss_pss_sha384:
case SignatureAlgorithm.rsa_pss_pss_sha512:
return ClientCertificateType.rsa_sign;
case SignatureAlgorithm.dsa:
return ClientCertificateType.dss_sign;
case SignatureAlgorithm.ecdsa:
case SignatureAlgorithm.ed25519:
case SignatureAlgorithm.ed448:
return ClientCertificateType.ecdsa_sign;
case SignatureAlgorithm.gostr34102012_256:
return ClientCertificateType.gost_sign256;
case SignatureAlgorithm.gostr34102012_512:
return ClientCertificateType.gost_sign512;
default:
return -1;
}
}
public static String getName(short signatureAlgorithm)
{
switch (signatureAlgorithm)
{
case anonymous:
return "anonymous";
case rsa:
return "rsa";
case dsa:
return "dsa";
case ecdsa:
return "ecdsa";
case ed25519:
return "ed25519";
case ed448:
return "ed448";
case gostr34102012_256:
return "gostr34102012_256";
case gostr34102012_512:
return "gostr34102012_512";
case rsa_pss_rsae_sha256:
return "rsa_pss_rsae_sha256";
case rsa_pss_rsae_sha384:
return "rsa_pss_rsae_sha384";
case rsa_pss_rsae_sha512:
return "rsa_pss_rsae_sha512";
case rsa_pss_pss_sha256:
return "rsa_pss_pss_sha256";
case rsa_pss_pss_sha384:
return "rsa_pss_pss_sha384";
case rsa_pss_pss_sha512:
return "rsa_pss_pss_sha512";
case ecdsa_brainpoolP256r1tls13_sha256:
return "ecdsa_brainpoolP256r1tls13_sha256";
case ecdsa_brainpoolP384r1tls13_sha384:
return "ecdsa_brainpoolP384r1tls13_sha384";
case ecdsa_brainpoolP512r1tls13_sha512:
return "ecdsa_brainpoolP512r1tls13_sha512";
default:
return "UNKNOWN";
}
}
public static String getText(short signatureAlgorithm)
{
return getName(signatureAlgorithm) + "(" + signatureAlgorithm + ")";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy