org.bouncycastle.pqc.crypto.xmss.XMSSAddress 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.pqc.crypto.xmss;
import org.bouncycastle.util.Pack;
/**
* XMSS address.
*/
public abstract class XMSSAddress
{
private final int layerAddress;
private final long treeAddress;
private final int type;
private final int keyAndMask;
protected XMSSAddress(Builder builder)
{
layerAddress = builder.layerAddress;
treeAddress = builder.treeAddress;
type = builder.type;
keyAndMask = builder.keyAndMask;
}
protected static abstract class Builder
{
/* mandatory */
private final int type;
/* optional */
private int layerAddress = 0;
private long treeAddress = 0L;
private int keyAndMask = 0;
protected Builder(int type)
{
super();
this.type = type;
}
protected T withLayerAddress(int val)
{
layerAddress = val;
return getThis();
}
protected T withTreeAddress(long val)
{
treeAddress = val;
return getThis();
}
protected T withKeyAndMask(int val)
{
keyAndMask = val;
return getThis();
}
protected abstract XMSSAddress build();
protected abstract T getThis();
}
protected byte[] toByteArray()
{
byte[] byteRepresentation = new byte[32];
Pack.intToBigEndian(layerAddress, byteRepresentation, 0);
Pack.longToBigEndian(treeAddress, byteRepresentation, 4);
Pack.intToBigEndian(type, byteRepresentation, 12);
Pack.intToBigEndian(keyAndMask, byteRepresentation, 28);
return byteRepresentation;
}
protected final int getLayerAddress()
{
return layerAddress;
}
protected final long getTreeAddress()
{
return treeAddress;
}
public final int getType()
{
return type;
}
public final int getKeyAndMask()
{
return keyAndMask;
}
}