![JAR search and dependency download from the Maven repository](/logo.png)
org.spongycastle.bcpg.sig.Features Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcpg-jdk15on Show documentation
Show all versions of bcpg-jdk15on Show documentation
Spongy Castle is a package-rename (org.bouncycastle.* to org.spongycastle.*) of Bouncy Castle
intended for the Android platform. Android unfortunately ships with a stripped-down version of
Bouncy Castle, which prevents easy upgrades - Spongy Castle overcomes this and provides a full,
up-to-date version of the Bouncy Castle cryptographic libs.
The newest version!
package org.spongycastle.bcpg.sig;
import org.spongycastle.bcpg.SignatureSubpacket;
import org.spongycastle.bcpg.SignatureSubpacketTags;
public class Features
extends SignatureSubpacket
{
/** Identifier for the modification detection feature */
public static final byte FEATURE_MODIFICATION_DETECTION = 1;
private static final byte[] featureToByteArray(byte feature)
{
byte[] data = new byte[1];
data[0] = feature;
return data;
}
public Features(
boolean critical,
boolean isLongLength,
byte[] data)
{
super(SignatureSubpacketTags.FEATURES, critical, isLongLength, data);
}
public Features(boolean critical, byte feature)
{
super(SignatureSubpacketTags.FEATURES, critical, false, featureToByteArray(feature));
}
/**
* Returns if modification detection is supported.
*/
public boolean supportsModificationDetection()
{
return supportsFeature(FEATURE_MODIFICATION_DETECTION);
}
/**
* Returns if a particular feature is supported.
*/
public boolean supportsFeature(byte feature)
{
for (int i = 0; i < data.length; i++)
{
if (data[i] == feature)
{
return true;
}
}
return false;
}
/**
* Sets support for a particular feature.
*/
private void setSupportsFeature(byte feature, boolean support)
{
if (feature == 0)
{
throw new IllegalArgumentException("feature == 0");
}
if (supportsFeature(feature) != support)
{
if (support == true)
{
byte[] temp = new byte[data.length + 1];
System.arraycopy(data, 0, temp, 0, data.length);
temp[data.length] = feature;
data = temp;
}
else
{
for (int i = 0; i < data.length; i++)
{
if (data[i] == feature)
{
byte[] temp = new byte[data.length - 1];
System.arraycopy(data, 0, temp, 0, i);
System.arraycopy(data, i + 1, temp, i, temp.length - i);
data = temp;
break;
}
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy