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/adapter/impl/operation/read.c

108 lines
2.3 KiB
C
Raw Normal View History

2019-03-26 22:04:53 +00:00
#include "webfuse/adapter/impl/operations.h"
2019-01-29 22:11:46 +00:00
2019-02-03 18:10:05 +00:00
#include <errno.h>
2019-01-29 22:11:46 +00:00
#include <string.h>
2019-01-29 22:47:08 +00:00
#include <limits.h>
2019-01-29 22:11:46 +00:00
#include <jansson.h>
2020-03-01 15:55:58 +00:00
#include "wf/jsonrpc/proxy.h"
2019-12-01 16:17:21 +00:00
#include "webfuse/core/base64.h"
#include "webfuse/core/json_util.h"
2019-01-29 22:11:46 +00:00
2019-03-26 22:04:53 +00:00
#define WF_MAX_READ_LENGTH 4096
2019-01-29 22:11:46 +00:00
2019-03-26 22:04:53 +00:00
static char * wf_impl_fill_buffer(
2019-01-29 22:11:46 +00:00
char const * data,
2019-03-03 17:02:02 +00:00
char const * format,
size_t count,
2019-03-26 22:04:53 +00:00
wf_status * status)
2019-01-29 22:11:46 +00:00
{
2019-03-26 22:04:53 +00:00
*status = WF_GOOD;
2019-12-01 16:17:21 +00:00
char * buffer = malloc(count);
2019-01-29 22:11:46 +00:00
if (0 < count)
2019-01-29 22:11:46 +00:00
{
if (0 == strcmp("identity", format))
{
memcpy(buffer, data, count);
2019-01-29 22:11:46 +00:00
}
2019-02-10 21:18:22 +00:00
else if (0 == strcmp("base64", format))
{
2019-12-01 16:17:21 +00:00
wf_base64_decode(data, strlen(data), (uint8_t *) buffer, count);
2019-02-10 21:18:22 +00:00
}
2019-01-29 22:11:46 +00:00
else
{
2019-03-26 22:04:53 +00:00
*status = WF_BAD;
2019-01-29 22:11:46 +00:00
}
}
2019-03-03 17:02:02 +00:00
return buffer;
2019-01-29 22:11:46 +00:00
}
static void wf_impl_operation_read_finished(
void * user_data,
json_t const * result,
json_t const * error)
2019-01-29 22:11:46 +00:00
{
wf_status status = wf_impl_jsonrpc_get_status(error);
2019-02-09 02:08:02 +00:00
fuse_req_t request = user_data;
2019-01-29 22:11:46 +00:00
2019-02-09 02:08:02 +00:00
char * buffer = NULL;
2019-02-09 18:02:53 +00:00
size_t length = 0;
if (NULL != result)
2019-01-29 22:11:46 +00:00
{
json_t * data_holder = json_object_get(result, "data");
json_t * format_holder = json_object_get(result, "format");
json_t * count_holder = json_object_get(result, "count");
2019-01-29 22:11:46 +00:00
2019-03-03 17:02:02 +00:00
if (json_is_string(data_holder) &&
json_is_string(format_holder) &&
json_is_integer(count_holder))
2019-01-29 22:11:46 +00:00
{
char const * const data = json_string_value(data_holder);
char const * const format = json_string_value(format_holder);
2019-02-09 02:08:02 +00:00
length = (size_t) json_integer_value(count_holder);
2019-01-29 22:11:46 +00:00
2019-03-26 22:04:53 +00:00
buffer = wf_impl_fill_buffer(data, format, length, &status);
2019-01-29 22:11:46 +00:00
}
else
{
2019-03-26 22:04:53 +00:00
status = WF_BAD_FORMAT;
2019-01-29 22:11:46 +00:00
}
}
2019-03-26 22:04:53 +00:00
if (WF_GOOD == status)
2019-01-29 22:11:46 +00:00
{
2019-02-09 02:08:02 +00:00
fuse_reply_buf(request, buffer, length);
2019-01-29 22:11:46 +00:00
}
2019-02-03 18:10:05 +00:00
else
{
fuse_reply_err(request, ENOENT);
}
free(buffer);
2019-02-09 02:08:02 +00:00
}
2019-03-26 22:04:53 +00:00
void wf_impl_operation_read(
2019-02-09 02:08:02 +00:00
fuse_req_t request,
fuse_ino_t inode,
size_t size,
off_t offset,
struct fuse_file_info * file_info)
{
2019-03-26 22:04:53 +00:00
struct wf_impl_operations_context * user_data = fuse_req_userdata(request);
2020-03-01 15:55:58 +00:00
struct wf_jsonrpc_proxy * rpc = wf_impl_operations_context_get_proxy(user_data);
2019-02-09 02:08:02 +00:00
if (NULL != rpc)
{
int const length = (size <= WF_MAX_READ_LENGTH) ? (int) size : WF_MAX_READ_LENGTH;
int handle = (file_info->fh & INT_MAX);
2020-03-01 15:55:58 +00:00
wf_jsonrpc_proxy_invoke(rpc, &wf_impl_operation_read_finished, request, "read", "siiii", user_data->name, (int) inode, handle, (int) offset, length);
}
else
{
fuse_reply_err(request, ENOENT);
}
2019-01-29 22:11:46 +00:00
}