1
0
mirror of https://github.com/falk-werner/webfuse synced 2025-06-13 12:54:15 +00:00

makes wsfs_server_config opaque

This commit is contained in:
Falk Werner 2019-03-10 00:06:13 +01:00
parent de9095a978
commit 9453a990cc
6 changed files with 150 additions and 48 deletions

View File

@ -12,7 +12,7 @@
struct args struct args
{ {
struct wsfs_server_config config; struct wsfs_server_config * config;
bool show_help; bool show_help;
}; };
@ -53,6 +53,7 @@ static int parse_arguments(int argc, char * argv[], struct args * args)
bool result = EXIT_SUCCESS; bool result = EXIT_SUCCESS;
bool finished = false; bool finished = false;
bool has_mountpoint = false;
while ((!finished) && (EXIT_SUCCESS == result)) while ((!finished) && (EXIT_SUCCESS == result))
{ {
int option_index = 0; int option_index = 0;
@ -68,27 +69,23 @@ static int parse_arguments(int argc, char * argv[], struct args * args)
finished = true; finished = true;
break; break;
case 'm': case 'm':
free(args->config.mount_point); wsfs_server_config_set_mountpoint(args->config, optarg);
args->config.mount_point = strdup(optarg); has_mountpoint = true;
break; break;
case 'd': case 'd':
free(args->config.document_root); wsfs_server_config_set_documentroot(args->config, optarg);
args->config.document_root = strdup(optarg);
break; break;
case 'c': case 'c':
free(args->config.cert_path); wsfs_server_config_set_certpath(args->config, optarg);
args->config.cert_path = strdup(optarg);
break; break;
case 'k': case 'k':
free(args->config.key_path); wsfs_server_config_set_keypath(args->config, optarg);
args->config.key_path = strdup(optarg);
break; break;
case 'n': case 'n':
free(args->config.vhost_name); wsfs_server_config_set_vhostname(args->config, optarg);
args->config.vhost_name = strdup(optarg);
break; break;
case 'p': case 'p':
args->config.port = atoi(optarg); wsfs_server_config_set_port(args->config, atoi(optarg));
break; break;
default: default:
fprintf(stderr, "error: unknown argument\n"); fprintf(stderr, "error: unknown argument\n");
@ -99,7 +96,7 @@ static int parse_arguments(int argc, char * argv[], struct args * args)
if ((EXIT_SUCCESS == result) && (!args->show_help)) if ((EXIT_SUCCESS == result) && (!args->show_help))
{ {
if (NULL == args->config.mount_point) if (!has_mountpoint)
{ {
fprintf(stderr, "error: missing mount point\n"); fprintf(stderr, "error: missing mount point\n");
result = EXIT_FAILURE; result = EXIT_FAILURE;
@ -123,26 +120,18 @@ static void on_interrupt(int signal_id)
int main(int argc, char * argv[]) int main(int argc, char * argv[])
{ {
struct args args = struct args args;
{ args.config = wsfs_server_config_create();
.config = wsfs_server_config_set_vhostname(args.config, "localhost");
{ wsfs_server_config_set_port(args.config, 8080);
.mount_point = NULL, args.show_help = false;
.document_root = NULL,
.cert_path = NULL,
.key_path = NULL,
.vhost_name = strdup("localhost"),
.port = 8080,
},
.show_help = 0
};
int result = parse_arguments(argc, argv, &args); int result = parse_arguments(argc, argv, &args);
if (!args.show_help) if (!args.show_help)
{ {
signal(SIGINT, on_interrupt); signal(SIGINT, on_interrupt);
server = wsfs_server_create(&args.config); server = wsfs_server_create(args.config);
if (NULL != server) if (NULL != server)
{ {
wsfs_server_run(server); wsfs_server_run(server);
@ -159,7 +148,7 @@ int main(int argc, char * argv[])
show_help(); show_help();
} }
wsfs_server_config_cleanup(&args.config); wsfs_server_config_dispose(args.config);
return result; return result;
} }

View File

@ -3,30 +3,42 @@
#include "wsfs/adapter/api.h" #include "wsfs/adapter/api.h"
struct wsfs_server_config struct wsfs_server_config;
{
char * mount_point;
char * document_root;
char * key_path;
char * cert_path;
char * vhost_name;
int port;
};
#ifdef __cplusplus #ifdef __cplusplus
extern "C" extern "C"
{ {
#endif #endif
extern WSFSA_API void wsfs_server_config_init( extern WSFSA_API struct wsfs_server_config * wsfs_server_config_create(void);
extern WSFSA_API void wsfs_server_config_dispose(
struct wsfs_server_config * config); struct wsfs_server_config * config);
extern WSFSA_API void wsfs_server_config_cleanup(
struct wsfs_server_config * config);
extern WSFSA_API void wsfs_server_config_clone( extern WSFSA_API void wsfs_server_config_set_mountpoint(
struct wsfs_server_config * config, struct wsfs_server_config * config,
struct wsfs_server_config * clone); char const * mount_point);
extern WSFSA_API void wsfs_server_config_set_documentroot(
struct wsfs_server_config * config,
char const * document_root);
extern WSFSA_API void wsfs_server_config_set_keypath(
struct wsfs_server_config * config,
char const * key_path);
extern WSFSA_API void wsfs_server_config_set_certpath(
struct wsfs_server_config * config,
char const * cert_path);
extern WSFSA_API void wsfs_server_config_set_vhostname(
struct wsfs_server_config * config,
char const * vhost_name);
extern WSFSA_API void wsfs_server_config_set_port(
struct wsfs_server_config * config,
int port);
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -4,7 +4,7 @@
#include <stdbool.h> #include <stdbool.h>
#include <libwebsockets.h> #include <libwebsockets.h>
#include "wsfs/adapter/server_config.h" #include "wsfs/adapter/server_config_intern.h"
#include "wsfs/adapter/server_protocol_intern.h" #include "wsfs/adapter/server_protocol_intern.h"
#define WSFS_DISABLE_LWS_LOG 0 #define WSFS_DISABLE_LWS_LOG 0

View File

@ -1,4 +1,4 @@
#include "wsfs/adapter/server_config.h" #include "wsfs/adapter/server_config_intern.h"
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
@ -43,3 +43,68 @@ void wsfs_server_config_clone(
clone->vhost_name = wsfs_server_config_strdup(config->vhost_name); clone->vhost_name = wsfs_server_config_strdup(config->vhost_name);
clone->port = config->port; clone->port = config->port;
} }
struct wsfs_server_config * wsfs_server_config_create(void)
{
struct wsfs_server_config * config = malloc(sizeof(struct wsfs_server_config));
if (NULL != config)
{
wsfs_server_config_init(config);
}
return config;
}
void wsfs_server_config_dispose(
struct wsfs_server_config * config)
{
wsfs_server_config_cleanup(config);
free(config);
}
void wsfs_server_config_set_mountpoint(
struct wsfs_server_config * config,
char const * mount_point)
{
free(config->mount_point);
config->mount_point = strdup(mount_point);
}
void wsfs_server_config_set_documentroot(
struct wsfs_server_config * config,
char const * document_root)
{
free(config->document_root);
config->document_root = strdup(document_root);
}
void wsfs_server_config_set_keypath(
struct wsfs_server_config * config,
char const * key_path)
{
free(config->key_path);
config->key_path = strdup(key_path);
}
void wsfs_server_config_set_certpath(
struct wsfs_server_config * config,
char const * cert_path)
{
free(config->cert_path);
config->cert_path = strdup(cert_path);
}
void wsfs_server_config_set_vhostname(
struct wsfs_server_config * config,
char const * vhost_name)
{
free(config->vhost_name);
config->vhost_name = strdup(vhost_name);
}
void wsfs_server_config_set_port(
struct wsfs_server_config * config,
int port)
{
config->port = port;
}

View File

@ -0,0 +1,35 @@
#ifndef WSFS_ADAPTER_SERVER_CONFIG_INTERN_H
#define WSFS_ADAPTER_SERVER_CONFIG_INTERN_H
#include "wsfs/adapter/server_config.h"
struct wsfs_server_config
{
char * mount_point;
char * document_root;
char * key_path;
char * cert_path;
char * vhost_name;
int port;
};
#ifdef __cplusplus
extern "C"
{
#endif
extern void wsfs_server_config_init(
struct wsfs_server_config * config);
extern void wsfs_server_config_cleanup(
struct wsfs_server_config * config);
extern void wsfs_server_config_clone(
struct wsfs_server_config * config,
struct wsfs_server_config * clone);
#ifdef __cplusplus
}
#endif
#endif

View File

@ -13,12 +13,13 @@ TEST(server, create_dispose)
{ {
mkdir("test", 0700); mkdir("test", 0700);
struct wsfs_server_config config = {strdup("test"), nullptr, nullptr, nullptr, nullptr, 0}; struct wsfs_server_config * config = wsfs_server_config_create();
struct wsfs_server * server = wsfs_server_create(&config); wsfs_server_config_set_mountpoint(config, "test");
struct wsfs_server * server = wsfs_server_create(config);
ASSERT_NE(nullptr, server); ASSERT_NE(nullptr, server);
wsfs_server_dispose(server); wsfs_server_dispose(server);
wsfs_server_config_cleanup(&config); wsfs_server_config_dispose(config);
rmdir("test"); rmdir("test");
} }