org.bouncycastle.jcajce.provider.digest.SHA3 Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcprov-jdk15to18 Show documentation
Show all versions of bcprov-jdk15to18 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.5 to JDK 1.8.
package org.bouncycastle.jcajce.provider.digest;
import org.bouncycastle.asn1.nist.NISTObjectIdentifiers;
import org.bouncycastle.crypto.CipherKeyGenerator;
import org.bouncycastle.crypto.digests.ParallelHash;
import org.bouncycastle.crypto.digests.SHA3Digest;
import org.bouncycastle.crypto.digests.SHAKEDigest;
import org.bouncycastle.crypto.digests.TupleHash;
import org.bouncycastle.crypto.macs.HMac;
import org.bouncycastle.crypto.macs.KMAC;
import org.bouncycastle.jcajce.provider.config.ConfigurableProvider;
import org.bouncycastle.jcajce.provider.symmetric.util.BaseKeyGenerator;
import org.bouncycastle.jcajce.provider.symmetric.util.BaseMac;
public class SHA3
{
private SHA3()
{
}
static public class DigestSHA3
extends BCMessageDigest
implements Cloneable
{
public DigestSHA3(int size)
{
super(new SHA3Digest(size));
}
public Object clone()
throws CloneNotSupportedException
{
BCMessageDigest d = (BCMessageDigest)super.clone();
d.digest = new SHA3Digest((SHA3Digest)digest);
return d;
}
}
static public class DigestSHAKE
extends BCMessageDigest
implements Cloneable
{
public DigestSHAKE(int type, int size)
{
super(new SHAKEDigest(type));
}
public Object clone()
throws CloneNotSupportedException
{
BCMessageDigest d = (BCMessageDigest)super.clone();
d.digest = new SHAKEDigest((SHAKEDigest)digest);
return d;
}
}
static public class DigestTupleHash
extends BCMessageDigest
implements Cloneable
{
public DigestTupleHash(int type, int size)
{
super(new TupleHash(type, null, size));
}
public Object clone()
throws CloneNotSupportedException
{
BCMessageDigest d = (BCMessageDigest)super.clone();
d.digest = new TupleHash((TupleHash)digest);
return d;
}
}
static public class DigestParallelHash
extends BCMessageDigest
implements Cloneable
{
public DigestParallelHash(int type, int size)
{
super(new ParallelHash(type, null, 128, size));
}
public Object clone()
throws CloneNotSupportedException
{
BCMessageDigest d = (BCMessageDigest)super.clone();
d.digest = new ParallelHash((ParallelHash)digest);
return d;
}
}
public static class HashMacSHA3
extends BaseMac
{
public HashMacSHA3(int size)
{
super(new HMac(new SHA3Digest(size)));
}
}
public static class KeyGeneratorSHA3
extends BaseKeyGenerator
{
public KeyGeneratorSHA3(int size)
{
super("HMACSHA3-" + size, size, new CipherKeyGenerator());
}
}
static public class Digest224
extends DigestSHA3
{
public Digest224()
{
super(224);
}
}
static public class Digest256
extends DigestSHA3
{
public Digest256()
{
super(256);
}
}
static public class Digest384
extends DigestSHA3
{
public Digest384()
{
super(384);
}
}
static public class Digest512
extends DigestSHA3
{
public Digest512()
{
super(512);
}
}
static public class DigestShake128_256
extends DigestSHAKE
{
public DigestShake128_256()
{
super(128, 256);
}
}
static public class DigestShake256_512
extends DigestSHAKE
{
public DigestShake256_512()
{
super(256, 512);
}
}
static public class HashMac224
extends HashMacSHA3
{
public HashMac224()
{
super(224);
}
}
static public class HashMac256
extends HashMacSHA3
{
public HashMac256()
{
super(256);
}
}
static public class HashMac384
extends HashMacSHA3
{
public HashMac384()
{
super(384);
}
}
static public class HashMac512
extends HashMacSHA3
{
public HashMac512()
{
super(512);
}
}
static public class KeyGenerator224
extends KeyGeneratorSHA3
{
public KeyGenerator224()
{
super(224);
}
}
static public class KeyGenerator256
extends KeyGeneratorSHA3
{
public KeyGenerator256()
{
super(256);
}
}
static public class KeyGenerator384
extends KeyGeneratorSHA3
{
public KeyGenerator384()
{
super(384);
}
}
static public class KeyGenerator512
extends KeyGeneratorSHA3
{
public KeyGenerator512()
{
super(512);
}
}
public static class KMac128
extends BaseMac
{
public KMac128()
{
super(new KMAC(128, new byte[0]));
}
}
public static class KMac256
extends BaseMac
{
public KMac256()
{
super(new KMAC(256, new byte[0]));
}
}
public static class DigestTupleHash128_256
extends DigestTupleHash
{
public DigestTupleHash128_256()
{
super(128, 256);
}
}
public static class DigestTupleHash256_512
extends DigestTupleHash
{
public DigestTupleHash256_512()
{
super(256, 512);
}
}
public static class DigestParallelHash128_256
extends DigestParallelHash
{
public DigestParallelHash128_256()
{
super(128, 256);
}
}
public static class DigestParallelHash256_512
extends DigestParallelHash
{
public DigestParallelHash256_512()
{
super(256, 512);
}
}
public static class Mappings
extends DigestAlgorithmProvider
{
private static final String PREFIX = SHA3.class.getName();
public Mappings()
{
}
public void configure(ConfigurableProvider provider)
{
provider.addAlgorithm("MessageDigest.SHA3-224", PREFIX + "$Digest224");
provider.addAlgorithm("MessageDigest.SHA3-256", PREFIX + "$Digest256");
provider.addAlgorithm("MessageDigest.SHA3-384", PREFIX + "$Digest384");
provider.addAlgorithm("MessageDigest.SHA3-512", PREFIX + "$Digest512");
provider.addAlgorithm("MessageDigest", NISTObjectIdentifiers.id_sha3_224, PREFIX + "$Digest224");
provider.addAlgorithm("MessageDigest", NISTObjectIdentifiers.id_sha3_256, PREFIX + "$Digest256");
provider.addAlgorithm("MessageDigest", NISTObjectIdentifiers.id_sha3_384, PREFIX + "$Digest384");
provider.addAlgorithm("MessageDigest", NISTObjectIdentifiers.id_sha3_512, PREFIX + "$Digest512");
provider.addAlgorithm("MessageDigest.SHAKE256-512", PREFIX + "$DigestShake256_512");
provider.addAlgorithm("MessageDigest.SHAKE128-256", PREFIX + "$DigestShake128_256");
provider.addAlgorithm("MessageDigest", NISTObjectIdentifiers.id_shake256, PREFIX + "$DigestShake256_512");
provider.addAlgorithm("MessageDigest", NISTObjectIdentifiers.id_shake128, PREFIX + "$DigestShake128_256");
provider.addAlgorithm("Alg.Alias.MessageDigest.SHAKE256", "SHAKE256-512");
provider.addAlgorithm("Alg.Alias.MessageDigest.SHAKE128", "SHAKE128-256");
addHMACAlgorithm(provider, "SHA3-224", PREFIX + "$HashMac224", PREFIX + "$KeyGenerator224");
addHMACAlias(provider, "SHA3-224", NISTObjectIdentifiers.id_hmacWithSHA3_224);
addHMACAlgorithm(provider, "SHA3-256", PREFIX + "$HashMac256", PREFIX + "$KeyGenerator256");
addHMACAlias(provider, "SHA3-256", NISTObjectIdentifiers.id_hmacWithSHA3_256);
addHMACAlgorithm(provider, "SHA3-384", PREFIX + "$HashMac384", PREFIX + "$KeyGenerator384");
addHMACAlias(provider, "SHA3-384", NISTObjectIdentifiers.id_hmacWithSHA3_384);
addHMACAlgorithm(provider, "SHA3-512", PREFIX + "$HashMac512", PREFIX + "$KeyGenerator512");
addHMACAlias(provider, "SHA3-512", NISTObjectIdentifiers.id_hmacWithSHA3_512);
addKMACAlgorithm(provider, "128", PREFIX + "$KMac128", PREFIX + "$KeyGenerator256");
addKMACAlgorithm(provider, "256", PREFIX + "$KMac256", PREFIX + "$KeyGenerator512");
provider.addAlgorithm("MessageDigest.TUPLEHASH256-512", PREFIX + "$DigestTupleHash256_512");
provider.addAlgorithm("MessageDigest.TUPLEHASH128-256", PREFIX + "$DigestTupleHash128_256");
provider.addAlgorithm("Alg.Alias.MessageDigest.TUPLEHASH256", "TUPLEHASH256-512");
provider.addAlgorithm("Alg.Alias.MessageDigest.TUPLEHASH128", "TUPLEHASH128-256");
provider.addAlgorithm("MessageDigest.PARALLELHASH256-512", PREFIX + "$DigestParallelHash256_512");
provider.addAlgorithm("MessageDigest.PARALLELHASH128-256", PREFIX + "$DigestParallelHash128_256");
provider.addAlgorithm("Alg.Alias.MessageDigest.PARALLELHASH256", "PARALLELHASH256-512");
provider.addAlgorithm("Alg.Alias.MessageDigest.PARALLELHASH128", "PARALLELHASH128-256");
}
}
}