eu.europa.ec.markt.dss.validation.xades.XAdESCertificateSource.java Source code

Java tutorial

Introduction

Here is the source code for eu.europa.ec.markt.dss.validation.xades.XAdESCertificateSource.java

Source

/*
 * DSS - Digital Signature Services
 *
 * Copyright (C) 2011 European Commission, Directorate-General Internal Market and Services (DG MARKT), B-1049 Bruxelles/Brussel
 *
 * Developed by: 2011 ARHS Developments S.A. (rue Nicolas Bov 2B, L-1253 Luxembourg) http://www.arhs-developments.com
 *
 * This file is part of the "DSS - Digital Signature Services" project.
 *
 * "DSS - Digital Signature Services" is free software: you can redistribute it and/or modify it under the terms of
 * the GNU Lesser General Public License as published by the Free Software Foundation, either version 2.1 of the
 * License, or (at your option) any later version.
 *
 * DSS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty
 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License along with
 * "DSS - Digital Signature Services".  If not, see <http://www.gnu.org/licenses/>.
 */

package eu.europa.ec.markt.dss.validation.xades;

import eu.europa.ec.markt.dss.signature.xades.XMLUtils;
import eu.europa.ec.markt.dss.validation.ades.SignatureCertificateSource;

import java.io.ByteArrayInputStream;
import java.security.cert.CertificateException;
import java.security.cert.CertificateFactory;
import java.security.cert.X509Certificate;
import java.util.ArrayList;
import java.util.List;

import org.apache.commons.codec.binary.Base64;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;

/**
 * 
 * Retrieve Certificates contained in a XAdES structure
 * 
 *
 * @version $Revision: 1867 $ - $Date: 2013-04-08 13:44:56 +0200 (Mon, 08 Apr 2013) $
 */

public class XAdESCertificateSource extends SignatureCertificateSource {

    private Element signatureElement;

    private boolean onlyExtended;

    /**
     * 
     * The default constructor for XAdESCertificateSource.
     * 
     * @param signatureElement
     */
    public XAdESCertificateSource(Element signatureElement, boolean onlyExtended) {
        this.signatureElement = signatureElement;
        this.onlyExtended = onlyExtended;
    }

    @Override
    public List<X509Certificate> getCertificates() {
        List<X509Certificate> list = new ArrayList<X509Certificate>();

        try {
            CertificateFactory factory = CertificateFactory.getInstance("X509");

            NodeList nodeList2 = (NodeList) XMLUtils.getNodeList(signatureElement,
                    "ds:Object/xades:QualifyingProperties/xades:UnsignedProperties/xades:UnsignedSignatureProperties/xades:CertificateValues/xades:EncapsulatedX509Certificate");
            for (int i = 0; i < nodeList2.getLength(); i++) {
                Element certEl = (Element) nodeList2.item(i);
                byte[] derEncoded = Base64.decodeBase64(certEl.getTextContent());
                X509Certificate cert = (X509Certificate) factory
                        .generateCertificate(new ByteArrayInputStream(derEncoded));
                if (!list.contains(cert)) {
                    list.add(cert);
                }
            }

            if (!onlyExtended) {
                NodeList nodeList = (NodeList) XMLUtils.getNodeList(signatureElement,
                        "ds:KeyInfo/ds:X509Data/ds:X509Certificate");
                for (int i = 0; i < nodeList.getLength(); i++) {
                    Element certEl = (Element) nodeList.item(i);
                    byte[] derEncoded = Base64.decodeBase64(certEl.getTextContent());
                    X509Certificate cert = (X509Certificate) factory
                            .generateCertificate(new ByteArrayInputStream(derEncoded));
                    if (!list.contains(cert)) {
                        list.add(cert);
                    }
                }
            }

        } catch (CertificateException e) {
            throw new RuntimeException(e);
        }

        return list;
    }
}