Autopsy  4.12.0
Graphical digital forensics platform for The Sleuth Kit and other tools.
Classes | Public Member Functions | Static Public Member Functions | Static Private Member Functions | Private Attributes | Static Private Attributes | List of all members
org.sleuthkit.autopsy.coreutils.ExecUtil Class Reference

Classes

class  InterruptedThreadProcessTerminator
 
interface  ProcessTerminator
 
class  StreamToStringRedirect
 
class  StreamToWriterRedirect
 
class  TimedProcessTerminator
 

Public Member Functions

synchronized String execute (final String aCommand, final String...params) throws IOException, InterruptedException
 
synchronized void execute (final Writer stdoutWriter, final String aCommand, final String...params) throws IOException, InterruptedException
 
synchronized int getExitValue ()
 
synchronized void stop ()
 

Static Public Member Functions

static int execute (ProcessBuilder processBuilder) throws SecurityException, IOException
 
static int execute (ProcessBuilder processBuilder, ProcessTerminator terminator) throws SecurityException, IOException
 
static int execute (ProcessBuilder processBuilder, long timeOut, TimeUnit units, ProcessTerminator terminator) throws SecurityException, IOException
 
static void killProcess (Process process)
 
static int waitForTermination (String command, Process process, ProcessTerminator terminator) throws SecurityException, IOException
 

Static Private Member Functions

static int waitForTermination (String command, Process process, long timeOut, TimeUnit units, ProcessTerminator terminator) throws SecurityException, IOException
 

Private Attributes

ExecUtil.StreamToStringRedirect errorStringRedirect = null
 
int exitValue = -100
 
ExecUtil.StreamToStringRedirect outputStringRedirect = null
 
ExecUtil.StreamToWriterRedirect outputWriterRedirect = null
 
Process proc = null
 

Static Private Attributes

static final long DEFAULT_TIMEOUT = 5
 
static final TimeUnit DEFAULT_TIMEOUT_UNITS = TimeUnit.SECONDS
 
static final Logger logger = Logger.getLogger(ExecUtil.class.getName())
 

Detailed Description

Executes a command line using an operating system process with a configurable timeout and pluggable logic to kill or continue the process on timeout.

Definition at line 37 of file ExecUtil.java.

Member Function Documentation

static int org.sleuthkit.autopsy.coreutils.ExecUtil.execute ( ProcessBuilder  processBuilder) throws SecurityException, IOException
static

Runs a process without a timeout and terminator.

Parameters
processBuilderA process builder used to configure and construct the process to be run.
Returns
the exit value of the process
Exceptions
SecurityExceptionif a security manager exists and vetoes any aspect of running the process.
IOExceptionif an I/O error occurs.

Definition at line 130 of file ExecUtil.java.

References org.sleuthkit.autopsy.coreutils.ExecUtil.execute().

Referenced by org.sleuthkit.autopsy.coreutils.ExecUtil.execute(), org.sleuthkit.autopsy.casemodule.LocalFilesDSProcessor.extractLogicalEvidenceFileContents(), and org.sleuthkit.autopsy.modules.plaso.PlasoIngestModule.process().

static int org.sleuthkit.autopsy.coreutils.ExecUtil.execute ( ProcessBuilder  processBuilder,
ProcessTerminator  terminator 
) throws SecurityException, IOException
static

Runs a process using the default timeout and a custom terminator.

Parameters
processBuilderA process builder used to configure and construct the process to be run.
terminatorThe terminator.
Returns
the exit value of the process
Exceptions
SecurityExceptionif a security manager exists and vetoes any aspect of running the process.
IOExceptionif an I/O error occurs.

Definition at line 152 of file ExecUtil.java.

References org.sleuthkit.autopsy.coreutils.ExecUtil.DEFAULT_TIMEOUT, org.sleuthkit.autopsy.coreutils.ExecUtil.DEFAULT_TIMEOUT_UNITS, and org.sleuthkit.autopsy.coreutils.ExecUtil.execute().

static int org.sleuthkit.autopsy.coreutils.ExecUtil.execute ( ProcessBuilder  processBuilder,
long  timeOut,
TimeUnit  units,
ProcessTerminator  terminator 
) throws SecurityException, IOException
static

Runs a process using a custom terminator.

Parameters
processBuilderA process builder used to configure and construct the process to be run.
timeOutThe duration of the timeout.
unitsThe units for the timeout.
terminatorThe terminator.
Returns
the exit value of the process
Exceptions
SecurityExceptionif a security manager exists and vetoes any aspect of running the process.
IOExceptionif an I/o error occurs.

Definition at line 171 of file ExecUtil.java.

References org.sleuthkit.autopsy.coreutils.Logger.getLogger(), and org.sleuthkit.autopsy.coreutils.ExecUtil.killProcess().

synchronized String org.sleuthkit.autopsy.coreutils.ExecUtil.execute ( final String  aCommand,
final String...  params 
) throws IOException, InterruptedException

Execute a process. Redirect asynchronously stdout to a string and stderr to nowhere. Use only for small outputs, otherwise use the execute() variant with Writer.

Parameters
aCommandcommand to be executed
paramsparameters of the command
Returns
string buffer with captured stdout

Definition at line 292 of file ExecUtil.java.

References org.sleuthkit.autopsy.coreutils.ExecUtil.errorStringRedirect, and org.sleuthkit.autopsy.coreutils.ExecUtil.outputStringRedirect.

synchronized void org.sleuthkit.autopsy.coreutils.ExecUtil.execute ( final Writer  stdoutWriter,
final String  aCommand,
final String...  params 
) throws IOException, InterruptedException

Execute a process. Redirect asynchronously stdout to a passed in writer and stderr to nowhere.

Parameters
stdoutWriterfile writer to write stdout to
aCommandcommand to be executed
paramsparameters of the command
Returns
string buffer with captured stdout

Definition at line 339 of file ExecUtil.java.

References org.sleuthkit.autopsy.coreutils.ExecUtil.errorStringRedirect, and org.sleuthkit.autopsy.coreutils.ExecUtil.outputWriterRedirect.

synchronized int org.sleuthkit.autopsy.coreutils.ExecUtil.getExitValue ( )

Gets the exit value returned by the subprocess used to execute a command.

Returns
The exit value or the distinguished value -100 if this method is called before the exit value is set.

Definition at line 412 of file ExecUtil.java.

References org.sleuthkit.autopsy.coreutils.ExecUtil.exitValue.

static void org.sleuthkit.autopsy.coreutils.ExecUtil.killProcess ( Process  process)
static
synchronized void org.sleuthkit.autopsy.coreutils.ExecUtil.stop ( )
static int org.sleuthkit.autopsy.coreutils.ExecUtil.waitForTermination ( String  command,
Process  process,
ProcessTerminator  terminator 
) throws SecurityException, IOException
static

Wait for the given process to finish, using the given ProcessTerminator.

Parameters
commandThe command that was used to start the process. Used only for logging purposes.
processThe process to wait for.
terminatorThe ProcessTerminator used to determine if the process should be killed.

exit value of the process

Exceptions
SecurityExceptionif a security manager exists and vetoes any aspect of running the process.
IOExceptionif an I/o error occurs.

Definition at line 215 of file ExecUtil.java.

References org.sleuthkit.autopsy.coreutils.ExecUtil.DEFAULT_TIMEOUT, org.sleuthkit.autopsy.coreutils.ExecUtil.DEFAULT_TIMEOUT_UNITS, and org.sleuthkit.autopsy.coreutils.ExecUtil.waitForTermination().

Referenced by org.sleuthkit.autopsy.modules.plaso.PlasoIngestModule.process(), and org.sleuthkit.autopsy.coreutils.ExecUtil.waitForTermination().

static int org.sleuthkit.autopsy.coreutils.ExecUtil.waitForTermination ( String  command,
Process  process,
long  timeOut,
TimeUnit  units,
ProcessTerminator  terminator 
) throws SecurityException, IOException
staticprivate

Member Data Documentation

final long org.sleuthkit.autopsy.coreutils.ExecUtil.DEFAULT_TIMEOUT = 5
staticprivate
final TimeUnit org.sleuthkit.autopsy.coreutils.ExecUtil.DEFAULT_TIMEOUT_UNITS = TimeUnit.SECONDS
staticprivate
ExecUtil.StreamToStringRedirect org.sleuthkit.autopsy.coreutils.ExecUtil.errorStringRedirect = null
private
int org.sleuthkit.autopsy.coreutils.ExecUtil.exitValue = -100
private
final Logger org.sleuthkit.autopsy.coreutils.ExecUtil.logger = Logger.getLogger(ExecUtil.class.getName())
staticprivate

Definition at line 274 of file ExecUtil.java.

Referenced by org.sleuthkit.autopsy.coreutils.ExecUtil.killProcess().

ExecUtil.StreamToStringRedirect org.sleuthkit.autopsy.coreutils.ExecUtil.outputStringRedirect = null
private
ExecUtil.StreamToWriterRedirect org.sleuthkit.autopsy.coreutils.ExecUtil.outputWriterRedirect = null
private
Process org.sleuthkit.autopsy.coreutils.ExecUtil.proc = null
private

Definition at line 275 of file ExecUtil.java.


The documentation for this class was generated from the following file:

Copyright © 2012-2018 Basis Technology. Generated on: Wed Sep 18 2019
This work is licensed under a Creative Commons Attribution-Share Alike 3.0 United States License.