port.org.bouncycastle.asn1.DERIA5String Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dss-model Show documentation
Show all versions of dss-model Show documentation
DSS Model contains the data model representation for DSS
package port.org.bouncycastle.asn1;
import java.io.IOException;
import port.org.bouncycastle.util.Arrays;
import port.org.bouncycastle.util.Strings;
/**
* DER IA5String object - this is an ascii string.
*/
public class DERIA5String extends ASN1Primitive implements ASN1String {
private byte[] string;
/**
* return a IA5 string from the passed in object
*
* @param obj
* a DERIA5String or an object that can be converted into one.
* @exception IllegalArgumentException
* if the object cannot be converted.
* @return a DERIA5String instance, or null.
*/
public static DERIA5String getInstance(Object obj) {
if ((obj == null) || (obj instanceof DERIA5String)) {
return (DERIA5String) obj;
}
if (obj instanceof byte[]) {
try {
return (DERIA5String) fromByteArray((byte[]) obj);
} catch (Exception e) {
throw new IllegalArgumentException("encoding error in getInstance: " + e.toString());
}
}
throw new IllegalArgumentException("illegal object in getInstance: " + obj.getClass().getName());
}
/**
* return an IA5 String from a tagged object.
*
* @param obj
* the tagged object holding the object we want
* @param explicit
* true if the object is meant to be explicitly
* tagged false otherwise.
* @exception IllegalArgumentException
* if the tagged object cannot
* be converted.
* @return a DERIA5String instance, or null.
*/
public static DERIA5String getInstance(ASN1TaggedObject obj, boolean explicit) {
ASN1Primitive o = obj.getObject();
if (explicit || (o instanceof DERIA5String)) {
return getInstance(o);
} else {
return new DERIA5String(((ASN1OctetString) o).getOctets());
}
}
/**
* basic constructor - with bytes.
*
* @param string
* the byte encoding of the characters making up the string.
*/
DERIA5String(byte[] string) {
this.string = string;
}
/**
* basic constructor - without validation.
*
* @param string
* the base string to use..
*/
public DERIA5String(String string) {
this(string, false);
}
/**
* Constructor with optional validation.
*
* @param string
* the base string to wrap.
* @param validate
* whether or not to check the string.
* @throws IllegalArgumentException
* if validate is true and the string
* contains characters that should not be in an IA5String.
*/
public DERIA5String(String string, boolean validate) {
if (string == null) {
throw new NullPointerException("string cannot be null");
}
if (validate && !isIA5String(string)) {
throw new IllegalArgumentException("string contains illegal characters");
}
this.string = Strings.toByteArray(string);
}
@Override
public String getString() {
return Strings.fromByteArray(string);
}
@Override
public String toString() {
return getString();
}
public byte[] getOctets() {
return Arrays.clone(string);
}
@Override
boolean isConstructed() {
return false;
}
@Override
int encodedLength() {
return 1 + StreamUtil.calculateBodyLength(string.length) + string.length;
}
@Override
void encode(ASN1OutputStream out) throws IOException {
out.writeEncoded(BERTags.IA5_STRING, string);
}
@Override
public int hashCode() {
return Arrays.hashCode(string);
}
@Override
boolean asn1Equals(ASN1Primitive o) {
if (!(o instanceof DERIA5String)) {
return false;
}
DERIA5String s = (DERIA5String) o;
return Arrays.areEqual(string, s.string);
}
/**
* return true if the passed in String can be represented without
* loss as an IA5String, false otherwise.
*
* @param str
* the string to check.
* @return true if character set in IA5String set, false otherwise.
*/
public static boolean isIA5String(String str) {
for (int i = str.length() - 1; i >= 0; i--) {
char ch = str.charAt(i);
if (ch > 0x007f) {
return false;
}
}
return true;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy