1
0
mirror of https://github.com/falk-werner/webfuse-provider synced 2024-10-27 20:44:10 +00:00
falk-werner_webfuse-provider/lib/webfuse/provider/impl/client.c

120 lines
3.0 KiB
C
Raw Normal View History

2019-03-26 22:04:53 +00:00
#include "webfuse/provider/impl/client.h"
2019-02-16 15:08:17 +00:00
2019-02-17 13:31:04 +00:00
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
#include <libwebsockets.h>
2019-03-26 22:04:53 +00:00
#include "webfuse/provider/impl/provider.h"
#include "webfuse/provider/impl/client_protocol.h"
#include "webfuse/provider/impl/client_config.h"
#include "webfuse/provider/impl/url.h"
2019-03-26 22:04:53 +00:00
#define WFP_PROTOCOL ("fs")
#define WFP_DISABLE_LWS_LOG 0
#define WFP_CLIENT_PROTOCOL_COUNT 2
#define WFP_CLIENT_TIMEOUT (1 * 1000)
2019-02-17 13:31:04 +00:00
2019-03-26 22:04:53 +00:00
struct wfp_client
2019-02-17 13:31:04 +00:00
{
volatile bool is_running;
2019-03-26 22:04:53 +00:00
struct wfp_client_protocol protocol;
struct lws_context_creation_info info;
2019-03-26 22:04:53 +00:00
struct lws_protocols protocols[WFP_CLIENT_PROTOCOL_COUNT];
struct lws_context * context;
char * key_path;
char * cert_path;
2019-02-17 13:31:04 +00:00
};
2019-03-26 22:04:53 +00:00
struct wfp_client * wfp_impl_client_create(
struct wfp_client_config * config)
2019-02-17 13:31:04 +00:00
{
2019-03-26 22:04:53 +00:00
lws_set_log_level(WFP_DISABLE_LWS_LOG, NULL);
2019-03-26 22:04:53 +00:00
struct wfp_client * client = malloc(sizeof(struct wfp_client));
2019-02-17 13:31:04 +00:00
if (NULL != client)
{
client->is_running = true;
2019-03-26 22:04:53 +00:00
wfp_impl_client_protocol_init(&client->protocol, &config->provider, config->user_data);
2019-03-26 22:04:53 +00:00
memset(client->protocols, 0, sizeof(struct lws_protocols) * WFP_CLIENT_PROTOCOL_COUNT);
2019-02-24 17:03:22 +00:00
client->protocols[0].name = "fs";
2019-03-26 22:04:53 +00:00
wfp_impl_client_protocol_init_lws(&client->protocol, &client->protocols[0]);
memset(&client->info, 0, sizeof(struct lws_context_creation_info));
client->info.port = CONTEXT_PORT_NO_LISTEN;
client->info.protocols = client->protocols;
client->info.uid = -1;
client->info.gid = -1;
if ((NULL != config->cert_path) && (NULL != config->key_path))
{
}
client->context = lws_create_context(&client->info);
2019-02-17 13:31:04 +00:00
}
return client;
}
2019-03-26 22:04:53 +00:00
void wfp_impl_client_dispose(
struct wfp_client * client)
2019-02-17 13:31:04 +00:00
{
lws_context_destroy(client->context);
2019-03-26 22:04:53 +00:00
wfp_impl_client_protocol_cleanup(&client->protocol);
2019-02-17 13:31:04 +00:00
free(client);
}
2019-03-26 22:04:53 +00:00
void wfp_impl_client_connect(
struct wfp_client * client,
2019-02-17 13:31:04 +00:00
char const * url)
{
2019-03-26 22:04:53 +00:00
struct wfp_impl_url url_data;
bool const success = wfp_impl_url_init(&url_data, url);
if (success)
{
struct lws_client_connect_info info;
memset(&info, 0, sizeof(struct lws_client_connect_info));
info.context = client->context;
info.port = url_data.port;
info.address = url_data.host;
info.path = url_data.path;
info.host = info.address;
info.origin = info.address;
info.ssl_connection = (url_data.use_tls) ? LCCSCF_USE_SSL : 0;
2019-03-26 22:04:53 +00:00
info.protocol = WFP_PROTOCOL;
2019-02-26 14:42:59 +00:00
info.pwsi = &client->protocol.wsi;
lws_client_connect_via_info(&info);
2019-03-26 22:04:53 +00:00
wfp_impl_url_cleanup(&url_data);
}
2019-02-17 13:31:04 +00:00
}
2019-03-26 22:04:53 +00:00
void wfp_impl_client_disconnect(
struct wfp_client * client)
2019-02-17 13:31:04 +00:00
{
(void) client;
// ToDo: implement me
}
2019-03-26 22:04:53 +00:00
void wfp_impl_client_run(
struct wfp_client * client)
2019-02-17 13:31:04 +00:00
{
while (client->is_running)
{
2019-03-26 22:04:53 +00:00
lws_service(client->context, WFP_CLIENT_TIMEOUT);
2019-02-17 13:31:04 +00:00
}
}
2019-03-26 22:04:53 +00:00
void wfp_impl_client_shutdown(
struct wfp_client * client)
2019-02-17 13:31:04 +00:00
{
client->is_running = false;
}