Package org.bouncycastle.oldcrypto.macs
Class I2PHMac
- java.lang.Object
-
- org.bouncycastle.oldcrypto.macs.I2PHMac
-
- All Implemented Interfaces:
Mac
public class I2PHMac extends Object implements Mac
HMAC implementation based on RFC2104 H(K XOR opad, H(K XOR ipad, text)) modified by jrandom to use the session key byte array directly and to cache a frequently used buffer (called on doFinal). changes released into the public domain in 2005. This is renamed from HMac because the constructor HMac(digest, sz) does not exist in the standard bouncycastle library, thus it conflicts in JVMs that contain the standard library (Android). As of 0.9.12, refactored to use standard MessageDigest. Deprecated - Do not use outside of router or Syndie. To be moved to router.
-
-
Constructor Summary
Constructors Constructor Description I2PHMac(MessageDigest digest)Deprecated.Use javax.crypto.MacI2PHMac(MessageDigest digest, int sz)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intdoFinal(byte[] out, int outOff)Compute the final statge of the MAC writing the output to the out parameter.StringgetAlgorithmName()Return the name of the algorithm the MAC implements.intgetMacSize()Return the block size for this cipher (in bytes).MessageDigestgetUnderlyingDigest()voidinit(byte[] key)Initialise the MAC.voidreset()Reset the mac generator.voidupdate(byte in)add a single byte to the mac for processing.voidupdate(byte[] in, int inOff, int len)
-
-
-
Constructor Detail
-
I2PHMac
@Deprecated public I2PHMac(MessageDigest digest)
Deprecated.Use javax.crypto.MacStandard HMAC, size == digest size.
-
I2PHMac
public I2PHMac(MessageDigest digest, int sz)
- Parameters:
sz- override the digest's size, nonstandard if different. SEE NOTES in HMACGenerator about why this isn't compatible with standard HmacMD5
-
-
Method Detail
-
getAlgorithmName
public String getAlgorithmName()
Description copied from interface:MacReturn the name of the algorithm the MAC implements.- Specified by:
getAlgorithmNamein interfaceMac- Returns:
- the name of the algorithm the MAC implements.
-
getUnderlyingDigest
public MessageDigest getUnderlyingDigest()
-
init
public void init(byte[] key)
Description copied from interface:MacInitialise the MAC.
-
getMacSize
public int getMacSize()
Description copied from interface:MacReturn the block size for this cipher (in bytes).- Specified by:
getMacSizein interfaceMac- Returns:
- the block size for this cipher in bytes.
-
update
public void update(byte in)
Description copied from interface:Macadd a single byte to the mac for processing.
-
update
public void update(byte[] in, int inOff, int len)
-
doFinal
public int doFinal(byte[] out, int outOff)Description copied from interface:MacCompute the final statge of the MAC writing the output to the out parameter.doFinal leaves the MAC in the same state it was after the last init.
-
-