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

com.helger.asic.CadesAsicManifest Maven / Gradle / Ivy

/**
 * Copyright (C) 2015-2017 difi (www.difi.no)
 * Copyright (C) 2018-2021 Philip Helger (www.helger.com)
 * philip[at]helger[dot]com
 *
 * This Source Code Form is subject to the terms of the
 * Mozilla Public License, v. 2.0.
 * If a copy of the MPL was not distributed
 * with this file, You can obtain one at
 * https://mozilla.org/MPL/2.0/
 */
package com.helger.asic;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.helger.asic.jaxb.AsicReader;
import com.helger.asic.jaxb.AsicWriter;
import com.helger.asic.jaxb.cades.ASiCManifestType;
import com.helger.asic.jaxb.cades.DataObjectReferenceType;
import com.helger.asic.jaxb.cades.SigReferenceType;
import com.helger.commons.base64.Base64;
import com.helger.commons.mime.IMimeType;
import com.helger.xsds.xmldsig.DigestMethodType;

public class CadesAsicManifest extends AbstractAsicManifest
{
  private static final Logger LOGGER = LoggerFactory.getLogger (AbstractAsicManifest.class);

  private final ASiCManifestType m_aManifest = new ASiCManifestType ();
  private boolean m_bRootFilenameIsSet = false;

  public CadesAsicManifest (@Nonnull final EMessageDigestAlgorithm eMDAlgo)
  {
    super (eMDAlgo);
  }

  @Override
  public void add (@Nonnull final String sFilename, @Nonnull final IMimeType aMimeType)
  {
    final DataObjectReferenceType aDataObjectRef = new DataObjectReferenceType ();
    aDataObjectRef.setURI (sFilename);
    aDataObjectRef.setMimeType (aMimeType.getAsString ());
    aDataObjectRef.setDigestValue (internalGetMessageDigest ().digest ());

    final DigestMethodType aDigestMethod = new DigestMethodType ();
    aDigestMethod.setAlgorithm (getMessageDigestAlgorithm ().getUri ());
    aDataObjectRef.setDigestMethod (aDigestMethod);

    m_aManifest.addDataObjectReference (aDataObjectRef);
    if (LOGGER.isDebugEnabled ())
      LOGGER.debug ("Digest: " + Base64.encodeBytes (aDataObjectRef.getDigestValue ()));
  }

  /**
   * Locates the DataObjectReference for the given file name and sets the
   * attribute Rootfile to Boolean.TRUE
   *
   * @param sEntryName
   *        name of entry for which the attribute Rootfile should
   *        be set to "true".
   */
  public void setRootfileForEntry (final String sEntryName)
  {
    if (m_bRootFilenameIsSet)
      throw new IllegalStateException ("Multiple root files are not allowed.");

    for (final DataObjectReferenceType aEntry : m_aManifest.getDataObjectReference ())
      if (aEntry.getURI ().equals (sEntryName))
      {
        aEntry.setRootfile (Boolean.TRUE);
        m_bRootFilenameIsSet = true;
        break;
      }
  }

  public void setSignature (final String sFilename, final String sMimeType)
  {
    final SigReferenceType aSigReference = new SigReferenceType ();
    aSigReference.setURI (sFilename);
    aSigReference.setMimeType (sMimeType);
    m_aManifest.setSigReference (aSigReference);
  }

  @Nonnull
  public ASiCManifestType getASiCManifest ()
  {
    return m_aManifest;
  }

  @Nullable
  public byte [] getAsBytes ()
  {
    return AsicWriter.asicManifest ().getAsBytes (m_aManifest);
  }

  public static String extractAndVerify (final String sXml, final ManifestVerifier aMV)
  {
    // Updating namespaces for compatibility with previous releases and other
    // implementations
    String sRealXML = sXml.replace ("http://uri.etsi.org/02918/v1.1.1#", "http://uri.etsi.org/02918/v1.2.1#");
    sRealXML = sRealXML.replace ("http://uri.etsi.org/2918/v1.2.1#", "http://uri.etsi.org/02918/v1.2.1#");
    sRealXML = sRealXML.replace ("http://www.w3.org/2000/09/xmldsig#sha", "http://www.w3.org/2001/04/xmlenc#sha");

    // Read XML
    final ASiCManifestType aManifest = AsicReader.asicManifest ().read (sRealXML);
    if (aManifest == null)
      throw new IllegalStateException ("Unable to read content as XML");

    String sSigReference = aManifest.getSigReference ().getURI ();
    if (sSigReference == null)
      sSigReference = "META-INF/signature.p7s";

    // Run through recorded objects
    for (final DataObjectReferenceType aDOR : aManifest.getDataObjectReference ())
    {
      aMV.update (aDOR.getURI (),
                  aDOR.getMimeType (),
                  aDOR.getDigestValue (),
                  aDOR.getDigestMethod ().getAlgorithm (),
                  sSigReference);
      if (aDOR.isRootfile () == Boolean.TRUE)
        aMV.setRootFilename (aDOR.getURI ());
    }

    return sSigReference;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy