2014-01-22 05:21:59 +00:00
|
|
|
/*
|
|
|
|
Serval DNA Rhizome HTTP interface
|
|
|
|
Copyright (C) 2013-2014 Serval Project Inc.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License
|
|
|
|
as published by the Free Software Foundation; either version 2
|
|
|
|
of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __SERVAL_DNA__RHIZOME_HTTP_H
|
|
|
|
#define __SERVAL_DNA__RHIZOME_HTTP_H
|
|
|
|
|
|
|
|
#include "rhizome.h"
|
2014-01-22 07:23:29 +00:00
|
|
|
#include "meshms.h"
|
2014-01-22 05:21:59 +00:00
|
|
|
#include "http_server.h"
|
|
|
|
|
|
|
|
int is_rhizome_http_server_running();
|
|
|
|
|
2014-01-22 07:23:29 +00:00
|
|
|
enum list_phase { LIST_HEADER = 0, LIST_ROWS, LIST_DONE };
|
|
|
|
|
2014-01-22 05:21:59 +00:00
|
|
|
typedef struct rhizome_http_request
|
|
|
|
{
|
|
|
|
struct http_request http; // MUST BE FIRST ELEMENT
|
|
|
|
|
|
|
|
/* Identify request from others being run. Monotonic counter feeds it. Only
|
|
|
|
* used for debugging when we write post-<uuid>.log files for multi-part form
|
|
|
|
* requests.
|
|
|
|
*/
|
|
|
|
unsigned int uuid;
|
|
|
|
|
|
|
|
/* For requests/responses that pertain to a single manifest.
|
|
|
|
*/
|
|
|
|
rhizome_manifest *manifest;
|
|
|
|
|
|
|
|
/* For requests/responses that pertain to a single identity.
|
|
|
|
*/
|
|
|
|
sid_t sid;
|
|
|
|
|
|
|
|
/* Finaliser for union contents (below).
|
|
|
|
*/
|
|
|
|
void (*finalise_union)(struct rhizome_http_request *);
|
|
|
|
|
|
|
|
/* Mutually exclusive response arguments.
|
|
|
|
*/
|
|
|
|
union {
|
|
|
|
|
|
|
|
/* For receiving Rhizome Direct import request
|
|
|
|
*/
|
|
|
|
struct {
|
|
|
|
// Which part is currently being received
|
|
|
|
const char *current_part;
|
|
|
|
// Temporary file currently current part is being written to
|
|
|
|
int part_fd;
|
|
|
|
// Which parts have already been received
|
|
|
|
bool_t received_manifest;
|
|
|
|
bool_t received_data;
|
|
|
|
// Name of data file supplied in part's Content-Disposition header, filename
|
|
|
|
// parameter (if any)
|
|
|
|
char data_file_name[MIME_FILENAME_MAXLEN + 1];
|
|
|
|
}
|
|
|
|
direct_import;
|
|
|
|
|
|
|
|
/* For receiving RESTful Rhizome insert request
|
|
|
|
*/
|
|
|
|
struct {
|
|
|
|
// Which part is currently being received
|
|
|
|
const char *current_part;
|
|
|
|
// Which parts have already been received
|
|
|
|
bool_t received_author;
|
|
|
|
bool_t received_secret;
|
|
|
|
bool_t received_manifest;
|
|
|
|
bool_t received_payload;
|
|
|
|
// For storing the "bundle-author" hex SID as we receive it
|
|
|
|
char author_hex[SID_STRLEN];
|
|
|
|
size_t author_hex_len;
|
|
|
|
sid_t author;
|
|
|
|
// For storing the "bundle-secret" hex as we receive it
|
|
|
|
char secret_hex[RHIZOME_BUNDLE_KEY_STRLEN];
|
|
|
|
size_t secret_hex_len;
|
|
|
|
rhizome_bk_t bundle_secret;
|
|
|
|
// The "force-new" parameter
|
|
|
|
char force_new_text[5]; // enough for "false"
|
|
|
|
size_t force_new_text_len;
|
|
|
|
bool_t force_new;
|
|
|
|
// For storing the manifest text (malloc/realloc) as we receive it
|
|
|
|
char *manifest_text;
|
|
|
|
size_t manifest_text_size;
|
|
|
|
size_t manifest_len;
|
|
|
|
// For receiving the payload
|
|
|
|
enum rhizome_payload_status payload_status;
|
|
|
|
uint64_t payload_size;
|
|
|
|
struct rhizome_write write;
|
|
|
|
}
|
|
|
|
insert;
|
|
|
|
|
|
|
|
/* For responses that send part or all of a payload.
|
|
|
|
*/
|
|
|
|
struct rhizome_read read_state;
|
|
|
|
|
|
|
|
/* For responses that list manifests.
|
|
|
|
*/
|
|
|
|
struct {
|
2014-01-22 07:23:29 +00:00
|
|
|
enum list_phase phase;
|
2014-01-22 05:21:59 +00:00
|
|
|
uint64_t rowid_highest;
|
|
|
|
size_t rowcount;
|
|
|
|
time_ms_t end_time;
|
|
|
|
struct rhizome_list_cursor cursor;
|
|
|
|
}
|
2014-01-22 07:23:29 +00:00
|
|
|
rhlist;
|
|
|
|
|
|
|
|
/* For responses that list MeshMS conversations.
|
|
|
|
*/
|
|
|
|
struct {
|
|
|
|
enum list_phase phase;
|
|
|
|
size_t rowcount;
|
|
|
|
struct meshms_conversations *conv;
|
|
|
|
struct meshms_conversation_iterator iter;
|
|
|
|
}
|
|
|
|
mclist;
|
2014-01-22 05:21:59 +00:00
|
|
|
|
|
|
|
} u;
|
|
|
|
|
|
|
|
} rhizome_http_request;
|
|
|
|
|
|
|
|
int rhizome_server_set_response(rhizome_http_request *r, const struct http_response *h);
|
|
|
|
int rhizome_server_free_http_request(rhizome_http_request *r);
|
|
|
|
int rhizome_server_http_send_bytes(rhizome_http_request *r);
|
|
|
|
int rhizome_server_parse_http_request(rhizome_http_request *r);
|
|
|
|
int rhizome_server_simple_http_response(rhizome_http_request *r, int result, const char *response);
|
|
|
|
int rhizome_server_http_response(rhizome_http_request *r, int result, const char *mime_type, const char *body, uint64_t bytes);
|
|
|
|
int rhizome_server_http_response_header(rhizome_http_request *r, int result, const char *mime_type, uint64_t bytes);
|
|
|
|
int rhizome_http_server_start(uint16_t port_low, uint16_t port_high);
|
|
|
|
|
|
|
|
int is_http_header_complete(const char *buf, size_t len, size_t read_since_last_call);
|
|
|
|
|
|
|
|
struct http_response_parts {
|
|
|
|
uint16_t code;
|
|
|
|
char *reason;
|
|
|
|
uint64_t range_start;
|
|
|
|
uint64_t content_length;
|
|
|
|
char *content_start;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define HTTP_RESPONSE_CONTENT_LENGTH_UNSET UINT64_MAX
|
|
|
|
|
|
|
|
int unpack_http_response(char *response, struct http_response_parts *parts);
|
|
|
|
|
|
|
|
#endif // __SERVAL_DNA__RHIZOME_HTTP_H
|