
com.anrisoftware.sscontrol.scripts.unix.InstallPackagesFactory 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.unix;
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;
/**
* Factory to create the install packages.
*
* @author Erwin Mueller, [email protected]
* @since 1.0
*/
public interface InstallPackagesFactory {
/**
* Create the install packages.
*
* @param args
* the {@link Map} arguments.
*
* - {@code log} the logger that logs the command output;
*
*
- {@code packages} the list of packages to install;
*
*
- {@code command} the install packages command.
*
*
- {@code system} the system name, for example
* {@code "ubuntu"}.
*
*
- {@code runCommands} optionally, set to the
* {@link RunCommands} to record the command.
*
*
- {@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 errString} optionally, set to {@code true} to save
* the error output in a {@link String} for later parsing, see
* {@link ProcessTask#getErr()}. Per default it is set to
* {@link AbstractProcessExec#ERR_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 InstallPackages}.
*/
InstallPackages create(Map args, Object parent,
Threads threads);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy