All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bouncycastle.tls.HashAlgorithm Maven / Gradle / Ivy

There is a newer version: 1.79
Show newest version
package org.bouncycastle.tls;

/**
 * RFC 5246 7.4.1.4.1
 */
public class HashAlgorithm
{
    public static final short none = 0;
    public static final short md5 = 1;
    public static final short sha1 = 2;
    public static final short sha224 = 3;
    public static final short sha256 = 4;
    public static final short sha384 = 5;
    public static final short sha512 = 6;

    /*
     * RFC 8422
     */
    public static final short Intrinsic = 8;

    public static String getName(short hashAlgorithm)
    {
        switch (hashAlgorithm)
        {
        case none:
            return "none";
        case md5:
            return "md5";
        case sha1:
            return "sha1";
        case sha224:
            return "sha224";
        case sha256:
            return "sha256";
        case sha384:
            return "sha384";
        case sha512:
            return "sha512";
        case Intrinsic:
            return "Intrinsic";
        default:
            return "UNKNOWN";
        }
    }

    public static int getOutputSize(short hashAlgorithm)
    {
        switch (hashAlgorithm)
        {
        case md5:
            return 16;
        case sha1:
            return 20;
        case sha224:
            return 28;
        case sha256:
            return 32;
        case sha384:
            return 48;
        case sha512:
            return 64;
        default:
            return -1;
        }
    }

    public static String getText(short hashAlgorithm)
    {
        return getName(hashAlgorithm) + "(" + hashAlgorithm + ")";
    }

    public static boolean isPrivate(short hashAlgorithm)
    {
        return 224 <= hashAlgorithm && hashAlgorithm <= 255; 
    }

    public static boolean isRecognized(short hashAlgorithm)
    {
        switch (hashAlgorithm)
        {
        case md5:
        case sha1:
        case sha224:
        case sha256:
        case sha384:
        case sha512:
        case Intrinsic:
            return true;
        default:
            return false;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy