Files
nwipe/src/options.h

74 lines
3.1 KiB
C
Raw Normal View History

2017-02-12 22:30:00 +01:00
/*
* options.h: Command line processing routines for nwipe.
*
* Copyright Darik Horn <dajhorn-dban@vanadac.com>.
2019-12-28 13:11:47 -05:00
*
2017-02-12 22:30:00 +01:00
* Modifications to original dwipe Copyright Andy Beverley <andy@andybev.com>
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, version 2.
*
* This program 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 General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, write to the Free Software Foundation, Inc.,
2019-12-28 13:11:47 -05:00
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
2017-02-12 22:30:00 +01:00
*
*/
#ifndef OPTIONS_H_
#define OPTIONS_H_
/* Program knobs. */
2019-12-28 13:11:47 -05:00
#define NWIPE_KNOB_ENTROPY "/dev/urandom"
#define NWIPE_KNOB_IDENTITY_SIZE 512
#define NWIPE_KNOB_LABEL_SIZE 128
#define NWIPE_KNOB_LOADAVG "/proc/loadavg"
#define NWIPE_KNOB_LOG_BUFFERSIZE 1024 // Maximum length of a log event.
#define NWIPE_KNOB_PARTITIONS "/proc/partitions"
#define NWIPE_KNOB_PARTITIONS_PREFIX "/dev/"
#define NWIPE_KNOB_PRNG_STATE_LENGTH 512 // 128 words
#define NWIPE_KNOB_SCSI "/proc/scsi/scsi"
#define NWIPE_KNOB_SLEEP 1
#define NWIPE_KNOB_STAT "/proc/stat"
#define MAX_NUMBER_EXCLUDED_DRIVES 10
#define MAX_DRIVE_PATH_LENGTH 200 // e.g. /dev/sda is only 8 characters long, so 200 should be plenty.
2020-11-23 12:11:08 +01:00
#define DEFAULT_SYNC_RATE 100000
2017-02-12 22:30:00 +01:00
/* Function prototypes for loading options from the environment and command line. */
int nwipe_options_parse( int argc, char** argv );
void nwipe_options_log( void );
/* Function to display help text */
void display_help();
2019-12-28 13:11:47 -05:00
typedef struct
2017-02-12 22:30:00 +01:00
{
2019-12-28 13:11:47 -05:00
int autonuke; // Do not prompt the user for confirmation when set.
2020-03-12 00:00:06 +00:00
int autopoweroff; // Power off on completion of wipe
2019-12-28 13:11:47 -05:00
int noblank; // Do not perform a final blanking pass.
int nousb; // Do not show or wipe any USB devices.
2019-12-28 13:11:47 -05:00
int nowait; // Do not wait for a final key before exiting.
int nosignals; // Do not allow signals to interrupt a wipe.
int nogui; // Do not show the GUI.
char* banner; // The product banner shown on the top line of the screen.
void* method; // A function pointer to the wipe method that will be used.
char logfile[FILENAME_MAX]; // The filename to log the output to.
2023-10-02 20:28:49 +02:00
char PDFreportpath[FILENAME_MAX]; // The path to write the PDF report to.
2019-12-28 13:11:47 -05:00
char exclude[MAX_NUMBER_EXCLUDED_DRIVES][MAX_DRIVE_PATH_LENGTH]; // Drives excluded from the search.
nwipe_prng_t* prng; // The pseudo random number generator implementation. pointer to the function.
int quiet; // Anonymize serial numbers
2019-12-28 13:11:47 -05:00
int rounds; // The number of times that the wipe method should be called.
int sync; // A flag to indicate whether and how often writes should be sync'd.
int verbose; // Make log more verbose
2019-12-28 13:11:47 -05:00
nwipe_verify_t verify; // A flag to indicate whether writes should be verified.
2017-02-12 22:30:00 +01:00
} nwipe_options_t;
extern nwipe_options_t nwipe_options;
#endif /* OPTIONS_H_ */