1
0
mirror of https://github.com/falk-werner/webfused synced 2024-10-27 20:44:08 +00:00
falk-werner_webfused/src/webfused/daemon.c

164 lines
3.1 KiB
C
Raw Normal View History

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"
#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
struct wfd_config * config = wfd_config_load_file(args.config_file);
bool success = (NULL != config);
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)
{
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
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;
}