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

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

Go to download

Generic implementation of ASiC-E archives in accordance with ETSI 102 918 v1.3.1.

There is a newer version: 3.0.1
Show newest version
/**
 * 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 java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.nio.file.Files;
import java.nio.file.Path;

import javax.annotation.Nonnull;
import javax.annotation.WillNotClose;

import com.helger.commons.mime.IMimeType;

public interface IAsicWriter
{
  /**
   * Adds another data object to the ASiC archive.
   *
   * @param aFile
   *        references the file to be added as a data object. The name of the
   *        entry is extracted from the File object.
   * @return reference to this AsicWriter
   * @throws IOException
   *         in case of IO error
   */
  @Nonnull
  default IAsicWriter add (@Nonnull final File aFile) throws IOException
  {
    return add (aFile.toPath ());
  }

  /**
   * Adds another data object to the ASiC container, using the supplied name as
   * the zip entry name
   *
   * @param aFile
   *        references the file to be added as a data object.
   * @param sFilename
   *        the archive entry name to be used.
   * @return reference to this AsicWriter
   * @throws IOException
   *         in case of error
   */
  @Nonnull
  default IAsicWriter add (@Nonnull final File aFile, @Nonnull final String sFilename) throws IOException
  {
    return add (aFile.toPath (), sFilename);
  }

  /**
   * Adds another data object to the ASiC archive
   *
   * @param aFile
   *        references the file to be added.
   * @return reference to this AsicWriter
   * @throws IOException
   *         in case of an IO error
   * @see #add(File)
   */
  @Nonnull
  default IAsicWriter add (@Nonnull final Path aFile) throws IOException
  {
    return add (aFile, aFile.toFile ().getName ());
  }

  /**
   * Adds another data object to the ASiC container under the entry name
   * provided.
   *
   * @param aFile
   *        reference to this AsicWriter.
   * @param sFilename
   *        the archive entry name to be used.
   * @return reference to this AsicWriter
   * @throws IOException
   *         in case of an IO error
   * @see #add(File, String)
   */
  @Nonnull
  default IAsicWriter add (@Nonnull final Path aFile, @Nonnull final String sFilename) throws IOException
  {
    try (final InputStream inputStream = Files.newInputStream (aFile))
    {
      add (inputStream, sFilename);
    }
    return this;
  }

  /**
   * Adds the data provided by the stream into the ASiC archive, using the name
   * of the supplied file as the entry name.
   *
   * @param aIS
   *        input stream of data.
   * @param sFilename
   *        the name of a file, which must be available in the file system in
   *        order to determine the MIME type.
   * @return reference to this AsicWriter
   * @throws IOException
   *         in case of an IO error
   */
  @Nonnull
  default IAsicWriter add (@Nonnull @WillNotClose final InputStream aIS,
                           @Nonnull final String sFilename) throws IOException
  {
    // Add file to container
    return add (aIS, sFilename, AsicUtils.detectMime (sFilename));
  }

  /**
   * Adds the contents of a file into the ASiC archive using the supplied entry
   * name and MIME type.
   *
   * @param aFile
   *        references the file to be added as a data object.
   * @param sFilename
   *        the archive entry name to be used.
   * @param aMimeType
   *        explicitly identifies the MIME type of the entry.
   * @return reference to this AsicWriter
   * @throws IOException
   *         in case of an IO error
   */
  @Nonnull
  default IAsicWriter add (@Nonnull final File aFile,
                           @Nonnull final String sFilename,
                           @Nonnull final IMimeType aMimeType) throws IOException
  {
    return add (aFile.toPath (), sFilename, aMimeType);
  }

  /**
   * Adds the contents of a file into the ASiC archive using the supplied entry
   * name and MIME type.
   *
   * @param aFile
   *        references the file to be added as a data object.
   * @param sFilename
   *        the archive entry name to be used.
   * @param aMimeType
   *        explicitly identifies the MIME type of the entry.
   * @return reference to this AsicWriter
   * @throws IOException
   *         on IO error
   */
  @Nonnull
  default IAsicWriter add (@Nonnull final Path aFile,
                           @Nonnull final String sFilename,
                           @Nonnull final IMimeType aMimeType) throws IOException
  {
    try (final InputStream aIS = Files.newInputStream (aFile))
    {
      add (aIS, sFilename, aMimeType);
    }
    return this;
  }

  /**
   * Adds the contents of an input stream into the ASiC archive, under a given
   * entry name and explicitly identifying the MIME type.
   *
   * @param aIS
   *        Input stream to add
   * @param sFilename
   *        the archive entry name to be used.
   * @param aMimeType
   *        explicitly identifies the MIME type of the entry.
   * @return reference to this AsicWriter
   * @throws IOException
   *         on IO error
   */
  @Nonnull
  IAsicWriter add (@Nonnull InputStream aIS,
                   @Nonnull String sFilename,
                   @Nonnull IMimeType aMimeType) throws IOException;

  /**
   * Specifies which entry (file) represents the "root" document, i.e. which
   * business document to read first.
   *
   * @param name
   *        of entry holding the root document.
   * @return reference to this AsicWriter
   */
  @Nonnull
  IAsicWriter setRootEntryName (String name);

  /**
   * Allows re-use of the same SignatureHelper object when creating multiple
   * ASiC archive and hence the need to create multiple signatures.
   *
   * @param aSH
   *        instantiated SignatureHelper
   * @return reference to this AsicWriter
   * @throws IOException
   *         in case of an IO error
   */
  @Nonnull
  IAsicWriter sign (@Nonnull SignatureHelper aSH) throws IOException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy