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

de.rub.nds.x509attacker.x509.handler.NameHandler 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.handler;

import de.rub.nds.protocol.xml.Pair;
import de.rub.nds.x509attacker.chooser.X509Chooser;
import de.rub.nds.x509attacker.constants.NameType;
import de.rub.nds.x509attacker.constants.X500AttributeType;
import de.rub.nds.x509attacker.x509.model.AttributeTypeAndValue;
import de.rub.nds.x509attacker.x509.model.Name;
import de.rub.nds.x509attacker.x509.model.RelativeDistinguishedName;
import java.util.LinkedList;
import java.util.List;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

/** The Subject of a Certificate becomes the issuer of the next certificate */
public class NameHandler extends X509FieldHandler {

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

    public NameHandler(X509Chooser chooser, Name name) {
        super(chooser, name);
    }

    @Override
    public void adjustContextAfterParse() {
        adjustContext();
    }

    @Override
    public void adjustContextAfterPrepare() {
        adjustContext();
    }

    public void adjustContext() {
        LOGGER.debug("Converting RDN to context RDN");
        List> rdnList = new LinkedList<>();
        for (RelativeDistinguishedName parsedRdn : component.getRelativeDistinguishedNames()) {
            for (AttributeTypeAndValue attributeTypeAndValue :
                    parsedRdn.getAttributeTypeAndValueList()) {
                rdnList.add(
                        new Pair<>(
                                attributeTypeAndValue.getAttributeTypeConfig(),
                                attributeTypeAndValue.getValueConfig()));
            }
        }
        LOGGER.debug("Converted into {} elements", rdnList.size());
        if (component.getType() == NameType.ISSUER) {
            context.setIssuer(rdnList);
        } else if (component.getType() == NameType.SUBJECT) {
            context.setSubject(rdnList);
        } else {
            throw new RuntimeException("Unknown NameType: " + component.getType().name());
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy