de.rub.nds.x509attacker.x509.parser.X509ComponentContainerParser Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of x509-attacker Show documentation
Show all versions of x509-attacker Show documentation
X.509-Attacker is a tool based on ASN.1 Tool for creating arbitrary certificates; including especially
invalid and malformed certificates. Since X.509 certificates encode their contents in ASN.1, this tool extends
the features of ASN.1 Tool in terms of certificate signing. Also, X.509-Attacker introduces a feature of
referencing XML elements in order to avoid redundancies when defining certificates in XML.
The newest version!
/*
* X.509-Attacker - A Library for Arbitrary X.509 Certificates
*
* Copyright 2014-2023 Ruhr University Bochum, Paderborn University, Technology Innovation Institute, and Hackmanit GmbH
*
* Licensed under Apache License, Version 2.0
* http://www.apache.org/licenses/LICENSE-2.0.txt
*/
package de.rub.nds.x509attacker.x509.parser;
import de.rub.nds.asn1.model.Asn1Container;
import de.rub.nds.x509attacker.chooser.X509Chooser;
import de.rub.nds.x509attacker.x509.model.X509Component;
import java.io.BufferedInputStream;
/**
* A parser for the X509 module that always parses the the structure of the asn1 field and then
* passes the content of the field to the implementation
*/
public abstract class X509ComponentContainerParser
extends X509ComponentFieldParser {
protected final Asn1Container container;
public X509ComponentContainerParser(X509Chooser chooser, Encodable encodable) {
super(chooser, encodable);
if (!(encodable instanceof Asn1Container)) {
throw new IllegalArgumentException("Encodable must be an Asn1Container.");
}
this.container = (Asn1Container) encodable;
}
protected final void parseContent(BufferedInputStream inputStream) {
container.setEncodedChildren(container.getContent().getValue());
parseSubcomponents(inputStream);
}
protected abstract void parseSubcomponents(BufferedInputStream inputStream);
}