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

com.anrisoftware.sscontrol.scripts.pack.PackFactory Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2014-2015 Erwin Müller 
 *
 * This file is part of sscontrol-scripts-unix.
 *
 * sscontrol-scripts-unix is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Affero General Public License as published by the
 * Free Software Foundation, either version 3 of the License, or (at your
 * option) any later version.
 *
 * sscontrol-scripts-unix 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 Affero General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with sscontrol-scripts-unix. If not, see .
 */
package com.anrisoftware.sscontrol.scripts.pack;

import java.io.File;
import java.util.List;
import java.util.Map;

import org.joda.time.Duration;

import com.anrisoftware.globalpom.exec.api.ProcessTask;
import com.anrisoftware.globalpom.exec.runcommands.RunCommands;
import com.anrisoftware.globalpom.exec.scriptprocess.AbstractProcessExec;
import com.anrisoftware.globalpom.threads.api.Threads;
import com.anrisoftware.sscontrol.scripts.unix.InstallPackages;

/**
 * Factory to create the archive from specified files.
 *
 * @author Erwin Mueller, [email protected]
 * @since 1.0
 */
public interface PackFactory {

    /**
     * Creates archive from specified files.
     *
     * @param args
     *            the {@link Map} arguments:
     *            
    *
  • {@code runCommands} optionally, set to the * {@link RunCommands} to record the command. * *
  • {@code files} the {@link File} files to pack; * *
  • {@code output} the output {@link File} archive; * *
  • {@code commands} set the {@link Map} of command to unpack * the archive for each archive type. *
      *
    • {@code tgz} tar/gz archive for extension {@code .tar.gz} *
    • {@code zip} Zip archive for extension {@code .zip} *
    * *
  • {@code outString} optionally, set to {@code true} to save * the output in a {@link String} for later parsing, see * {@link ProcessTask#getOut()}. Per default it is set to * {@link AbstractProcessExec#OUT_STRING_DEFAULT}. * *
  • {@code timeout} optionally, set the timeout * {@link Duration}. Per default it is set to * {@link InstallPackages#TIMEOUT_DEFAULT}. * *
  • {@code destroyOnTimeout} optionally, set to {@code true} * to destroy the process on timeout. Per default it is set to * {@link AbstractProcessExec#DESTROY_ON_TIMEOUT_DEFAULT}. * *
  • {@code checkExitCodes} optionally, set to {@code true} to * check the exit code(s) of the process; * *
  • {@code exitCodes} optionally, set a {@link List} of * success exit codes; * *
  • {@code exitCode} optionally, set the success exit code of * the process. Per default it is set to * {@link AbstractProcessExec#EXIT_CODE_DEFAULT}. *
* * @param parent * the {@link Object} parent script. * * @param threads * the {@link Threads} pool. * * @return the {@link Pack}. */ Pack create(Map args, Object parent, Threads threads); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy