All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.rub.nds.x509attacker.x509.parser.PublicKeyBitStringParser Maven / Gradle / Ivy

Go to download

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.parser.Asn1Parser;
import de.rub.nds.asn1.parser.ParserHelper;
import de.rub.nds.modifiablevariable.util.ArrayConverter;
import de.rub.nds.x509attacker.chooser.X509Chooser;
import de.rub.nds.x509attacker.x509.model.publickey.PublicKeyBitString;
import java.io.BufferedInputStream;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class PublicKeyBitStringParser extends Asn1Parser implements X509Parser {

    private static final Logger LOGGER = LogManager.getLogger();

    private final PublicKeyBitString publicKeyBitString;

    private final X509Chooser chooser;

    public PublicKeyBitStringParser(X509Chooser chooser, PublicKeyBitString publicKeyBitString) {
        super(publicKeyBitString);
        this.publicKeyBitString = publicKeyBitString;
        this.chooser = chooser;
    }

    @Override
    public void parse(BufferedInputStream inputStream) {
        LOGGER.debug("Parsing PublicKeyBitString");
        ParserHelper.parseAsn1BitString(publicKeyBitString, inputStream);
        /**
         * The content of the public key bitstring itself has structure, so we need to parse it as
         * well.
         */
        LOGGER.debug(
                "PublicKey content: {}",
                ArrayConverter.bytesToHexString(publicKeyBitString.getUsedBits().getValue()));
        publicKeyBitString.setX509PublicKeyContent(
                publicKeyBitString.createX509PublicKeyContent(chooser.getSubjectPublicKeyType()));
        publicKeyBitString
                .getX509PublicKeyContent()
                .readIn(chooser, publicKeyBitString.getUsedBits().getValue());
        publicKeyBitString.getX509PublicKeyContent().adjustInContext(chooser);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy