static void usage()
{
fprintf(stderr, _(
-"\nVersion: " VERSION " (" DATE ")\n\n"
+"\nVersion: " VERSION " (" BDATE ")\n\n"
"Usage: stored [-s -f ] [-c config_file] [-d debug_level] [config_file]\n"
" -c <file> use <file> as configuration file\n"
" -dnn set debug level to nn\n"
" -f run in foreground (for debugging)\n"
+" -g groupid\n"
" -s no signals (for debugging)\n"
" -t test - read config and exit\n"
+" -u userid\n"
+" -v verbose user messages\n"
" -? print this message.\n"
"\n"));
exit(1);
int no_signals = FALSE;
int test_config = FALSE;
pthread_t thid;
+ char *uid = NULL;
+ char *gid = NULL;
init_stack_dump();
my_name_is(argc, argv, "stored");
Emsg1(M_ABORT, 0, "Tape block size (%d) is not a power of 2\n", TAPE_BSIZE);
}
- while ((ch = getopt(argc, argv, "c:d:fst?")) != -1) {
+ while ((ch = getopt(argc, argv, "c:d:fg:stu:v?")) != -1) {
switch (ch) {
case 'c': /* configuration file */
if (configfile != NULL) {
foreground = TRUE;
break;
+ case 'g': /* set group id */
+ gid = optarg;
+ break;
+
case 's': /* no signals */
no_signals = TRUE;
break;
test_config = TRUE;
break;
+ case 'u': /* set uid */
+ uid = optarg;
+ break;
+
+ case 'v': /* verbose */
+ verbose++;
+ break;
+
case '?':
default:
usage();
init_stack_dump(); /* pick up new pid */
}
+ drop(uid, gid);
+
create_pid_file(me->pid_directory, "bacula-sd", me->SDport);
/* Ensure that Volume Session Time and Id are both