2020-03-08 10:44:17 +00:00
|
|
|
#include "webfused/daemon.h"
|
|
|
|
|
2020-02-09 14:04:58 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <signal.h>
|
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <getopt.h>
|
|
|
|
|
2020-07-05 09:19:00 +00:00
|
|
|
#include <webfuse/webfuse.h>
|
2020-03-17 21:53:38 +00:00
|
|
|
#include "webfused/config/config.h"
|
|
|
|
#include "webfused/config/factory.h"
|
|
|
|
#include "webfused/log/log.h"
|
2020-03-18 08:38:25 +00:00
|
|
|
#include "webfused/log/logger.h"
|
|
|
|
#include "webfused/log/stderr_logger.h"
|
2020-03-19 11:42:47 +00:00
|
|
|
#include "webfused/change_user.h"
|
2020-02-09 14:04:58 +00:00
|
|
|
|
2020-03-17 21:53:38 +00:00
|
|
|
#define WFD_SERVICE_TIMEOUT (1 * 1000)
|
2020-03-20 17:01:36 +00:00
|
|
|
#define WFD_DEFAULT_CONFIG_FILE ("/etc/webfused.conf")
|
2020-02-09 14:04:58 +00:00
|
|
|
|
|
|
|
struct args
|
|
|
|
{
|
2020-03-17 21:53:38 +00:00
|
|
|
char * config_file;
|
2020-02-09 14:04:58 +00:00
|
|
|
bool show_help;
|
|
|
|
};
|
|
|
|
|
|
|
|
static bool shutdown_requested = false;
|
|
|
|
|
|
|
|
static void show_help(void)
|
|
|
|
{
|
|
|
|
printf(
|
2020-03-17 21:53:38 +00:00
|
|
|
"webfused, Copyright (c) 2019-2020, webfused authors <https://github.com/falk-werner/webfused>\n"
|
2020-02-09 14:04:58 +00:00
|
|
|
"Websocket file system daemon\n"
|
|
|
|
"\n"
|
2020-03-17 21:53:38 +00:00
|
|
|
"Usage: webfused [-f <config file>] | -h\n"
|
2020-02-09 14:04:58 +00:00
|
|
|
"\n"
|
|
|
|
"Options:\n"
|
2020-03-17 21:53:38 +00:00
|
|
|
"\t-f, --config-file Path to config file (default: /etc/webfuse.conf)\n"
|
|
|
|
"\t-h, --help Print this message and terminate\n"
|
2020-02-09 14:04:58 +00:00
|
|
|
"\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
static int parse_arguments(int argc, char * argv[], struct args * args)
|
|
|
|
{
|
|
|
|
static struct option const options[] =
|
|
|
|
{
|
2020-03-17 21:53:38 +00:00
|
|
|
{"config-file", required_argument, NULL, 'f'},
|
2020-02-09 14:04:58 +00:00
|
|
|
{"help", no_argument, NULL, 'h'},
|
|
|
|
{NULL, 0, NULL, 0}
|
|
|
|
};
|
|
|
|
|
2020-03-17 21:53:38 +00:00
|
|
|
args->config_file = strdup(WFD_DEFAULT_CONFIG_FILE);
|
|
|
|
args->show_help = false;
|
|
|
|
|
2020-02-09 14:04:58 +00:00
|
|
|
bool result = EXIT_SUCCESS;
|
|
|
|
bool finished = false;
|
2020-03-18 17:00:53 +00:00
|
|
|
optind = 0;
|
2020-02-09 14:04:58 +00:00
|
|
|
while ((!finished) && (EXIT_SUCCESS == result))
|
|
|
|
{
|
|
|
|
int option_index = 0;
|
2020-03-17 21:53:38 +00:00
|
|
|
int const c = getopt_long(argc, argv, "f:h", options, &option_index);
|
2020-02-09 14:04:58 +00:00
|
|
|
|
|
|
|
switch (c)
|
|
|
|
{
|
|
|
|
case -1:
|
|
|
|
finished = true;
|
|
|
|
break;
|
|
|
|
case 'h':
|
|
|
|
args->show_help = true;
|
|
|
|
finished = true;
|
|
|
|
break;
|
2020-03-17 21:53:38 +00:00
|
|
|
case 'f':
|
|
|
|
free(args->config_file);
|
|
|
|
args->config_file = strdup(optarg);
|
2020-02-09 14:04:58 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
fprintf(stderr, "error: unknown argument\n");
|
|
|
|
result = EXIT_FAILURE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (EXIT_SUCCESS != result)
|
|
|
|
{
|
|
|
|
args->show_help = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void on_interrupt(int signal_id)
|
|
|
|
{
|
|
|
|
(void) signal_id;
|
|
|
|
|
|
|
|
shutdown_requested = true;
|
|
|
|
}
|
|
|
|
|
2020-03-08 10:44:17 +00:00
|
|
|
int wfd_daemon_run(int argc, char * argv[])
|
2020-02-09 14:04:58 +00:00
|
|
|
{
|
2020-03-18 16:33:31 +00:00
|
|
|
wfd_stderr_logger_init(WFD_LOGLEVEL_ALL, NULL);
|
2020-02-09 14:04:58 +00:00
|
|
|
|
2020-03-17 21:53:38 +00:00
|
|
|
struct args args;
|
2020-02-09 14:04:58 +00:00
|
|
|
int result = parse_arguments(argc, argv, &args);
|
|
|
|
|
|
|
|
if (!args.show_help)
|
|
|
|
{
|
|
|
|
signal(SIGINT, on_interrupt);
|
2020-03-17 21:53:38 +00:00
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_file(args.config_file);
|
|
|
|
bool success = (NULL != config);
|
|
|
|
|
2020-03-19 11:42:47 +00:00
|
|
|
if (!success)
|
|
|
|
{
|
|
|
|
fprintf(stderr, "fatal: failed to load server config\n");
|
|
|
|
result = EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
{
|
|
|
|
success = wfd_change_user(
|
|
|
|
wfd_config_get_user(config),
|
|
|
|
wfd_config_get_group(config));
|
|
|
|
}
|
|
|
|
|
2020-03-17 21:53:38 +00:00
|
|
|
if (success)
|
2020-02-09 14:04:58 +00:00
|
|
|
{
|
2020-03-17 21:53:38 +00:00
|
|
|
struct wf_server_config * server_config = wfd_config_get_server_config(config);
|
|
|
|
struct wf_server * server = wf_server_create(server_config);
|
|
|
|
if (NULL != server)
|
2020-02-09 14:04:58 +00:00
|
|
|
{
|
2020-03-17 21:53:38 +00:00
|
|
|
while (!shutdown_requested)
|
|
|
|
{
|
2020-05-24 19:09:41 +00:00
|
|
|
wf_server_service(server);
|
2020-03-17 21:53:38 +00:00
|
|
|
}
|
2020-02-09 14:04:58 +00:00
|
|
|
|
2020-03-17 21:53:38 +00:00
|
|
|
wf_server_dispose(server);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
fprintf(stderr, "fatal: unable start server\n");
|
|
|
|
result = EXIT_FAILURE;
|
|
|
|
}
|
2020-02-09 14:04:58 +00:00
|
|
|
}
|
2020-03-17 21:53:38 +00:00
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
if (NULL != config)
|
|
|
|
{
|
|
|
|
wfd_config_dispose(config);
|
|
|
|
}
|
2020-02-09 14:04:58 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
show_help();
|
|
|
|
}
|
|
|
|
|
2020-03-18 08:38:25 +00:00
|
|
|
wfd_logger_close();
|
2020-03-17 21:53:38 +00:00
|
|
|
free(args.config_file);
|
2020-03-18 17:00:53 +00:00
|
|
|
shutdown_requested = false;
|
2020-02-09 14:04:58 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|