com.googlecode.gwt.crypto.bouncycastle.paddings.ZeroBytePadding Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gwt-crypto Show documentation
Show all versions of gwt-crypto Show documentation
A partial port of the Bouncycastle J2ME crypto library with
parts taken from GWTx.
The newest version!
package com.googlecode.gwt.crypto.bouncycastle.paddings;
import com.googlecode.gwt.crypto.bouncycastle.InvalidCipherTextException;
import com.googlecode.gwt.crypto.util.SecureRandom;
/**
* A padder that adds NULL byte padding to a block.
*/
public class ZeroBytePadding
implements BlockCipherPadding
{
/**
* Initialise the padder.
*
* @param random - a SecureRandom if available.
*/
@Override
public void init(SecureRandom random)
throws IllegalArgumentException
{
// nothing to do.
}
/**
* Return the name of the algorithm the padder implements.
*
* @return the name of the algorithm the padder implements.
*/
@Override
public String getPaddingName()
{
return "ZeroByte";
}
/**
* add the pad bytes to the passed in block, returning the
* number of bytes added.
*/
@Override
public int addPadding(
byte[] in,
int inOff)
{
int added = (in.length - inOff);
while (inOff < in.length)
{
in[inOff] = (byte) 0;
inOff++;
}
return added;
}
/**
* return the number of pad bytes present in the block.
*/
@Override
public int padCount(byte[] in)
throws InvalidCipherTextException
{
int count = in.length;
while (count > 0)
{
if (in[count - 1] != 0)
{
break;
}
count--;
}
return in.length - count;
}
}