GNUnet 0.22.0
config_plugin.c File Reference
#include "platform.h"
#include "gnunet_rest_plugin.h"
#include <gnunet_rest_lib.h>
#include <gnunet_util_lib.h>
#include <jansson.h>
#include "config_plugin.h"
Include dependency graph for config_plugin.c:

Go to the source code of this file.

Data Structures

struct  Plugin
 Handle for a plugin. More...
 
struct  RequestHandle
 The request handle. More...
 

Macros

#define GNUNET_REST_API_NS_CONFIG   "/config"
 

Functions

static void cleanup_handle (struct RequestHandle *handle)
 Cleanup request handle. More...
 
static void do_error (void *cls)
 Task run on shutdown. More...
 
static void add_sections (void *cls, const char *section, const char *option, const char *value)
 
static void add_section_contents (void *cls, const char *section, const char *option, const char *value)
 
static void get_cont (struct GNUNET_REST_RequestHandle *con_handle, const char *url, void *cls)
 Handle rest request. More...
 
static struct GNUNET_CONFIGURATION_Handleset_value (struct GNUNET_CONFIGURATION_Handle *config, const char *section, const char *option, json_t *value)
 
static void set_cont (struct GNUNET_REST_RequestHandle *con_handle, const char *url, void *cls)
 Handle REST POST request. More...
 
static void options_cont (struct GNUNET_REST_RequestHandle *con_handle, const char *url, void *cls)
 Handle rest request. More...
 
enum GNUNET_GenericReturnValue REST_config_process_request (void *plugin, struct GNUNET_REST_RequestHandle *conndata_handle, GNUNET_REST_ResultProcessor proc, void *proc_cls)
 Function processing the REST call. More...
 
void REST_config_done (struct GNUNET_REST_Plugin *api)
 Exit point from the plugin. More...
 
void * REST_config_init (const struct GNUNET_CONFIGURATION_Handle *c)
 Entry point for the plugin. More...
 

Variables

const struct GNUNET_CONFIGURATION_Handleconfig_cfg
 
static struct RequestHandlerequests_head
 DLL. More...
 
static struct RequestHandlerequests_tail
 DLL. More...
 

Macro Definition Documentation

◆ GNUNET_REST_API_NS_CONFIG

#define GNUNET_REST_API_NS_CONFIG   "/config"

Definition at line 34 of file config_plugin.c.

Function Documentation

◆ cleanup_handle()

static void cleanup_handle ( struct RequestHandle handle)
static

Cleanup request handle.

Parameters
handleHandle to clean up

Definition at line 102 of file config_plugin.c.

103{
104 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Cleaning up\n");
105 if (NULL != handle->url)
106 GNUNET_free (handle->url);
109 handle);
111}
static struct RequestHandle * requests_head
DLL.
Definition: config_plugin.c:88
static struct RequestHandle * requests_tail
DLL.
Definition: config_plugin.c:93
static struct GNUNET_VPN_Handle * handle
Handle to vpn service.
Definition: gnunet-vpn.c:35
#define GNUNET_CONTAINER_DLL_remove(head, tail, element)
Remove an element from a DLL.
#define GNUNET_log(kind,...)
@ GNUNET_ERROR_TYPE_DEBUG
#define GNUNET_free(ptr)
Wrapper around free.

References GNUNET_CONTAINER_DLL_remove, GNUNET_ERROR_TYPE_DEBUG, GNUNET_free, GNUNET_log, handle, requests_head, and requests_tail.

Referenced by do_error(), get_cont(), options_cont(), REST_config_done(), REST_config_process_request(), and set_cont().

Here is the caller graph for this function:

◆ do_error()

static void do_error ( void *  cls)
static

Task run on shutdown.

Cleans up everything.

Parameters
clsunused

Definition at line 120 of file config_plugin.c.

121{
122 struct RequestHandle *handle = cls;
123 struct MHD_Response *resp;
124
125 resp = GNUNET_REST_create_response (NULL);
126 handle->proc (handle->proc_cls, resp, handle->response_code);
128}
static void cleanup_handle(struct RequestHandle *handle)
Cleanup request handle.
struct MHD_Response * GNUNET_REST_create_response(const char *data)
Create REST MHD response.
Definition: rest.c:44
The request handle.
Definition: config_plugin.c:47

References cleanup_handle(), GNUNET_REST_create_response(), and handle.

Referenced by get_cont(), and set_cont().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ add_sections()

static void add_sections ( void *  cls,
const char *  section,
const char *  option,
const char *  value 
)
static

Definition at line 132 of file config_plugin.c.

136{
137 json_t *sections_obj = cls;
138 json_t *sec_obj;
139
140 sec_obj = json_object_get (sections_obj, section);
141 if (NULL != sec_obj)
142 {
143 json_object_set_new (sec_obj, option, json_string (value));
144 return;
145 }
146 sec_obj = json_object ();
147 json_object_set_new (sec_obj, option, json_string (value));
148 json_object_set_new (sections_obj, section, sec_obj);
149}
static char * value
Value of the record to add/remove.

References value.

Referenced by get_cont().

Here is the caller graph for this function:

◆ add_section_contents()

static void add_section_contents ( void *  cls,
const char *  section,
const char *  option,
const char *  value 
)
static

Definition at line 153 of file config_plugin.c.

157{
158 json_t *section_obj = cls;
159
160 json_object_set_new (section_obj, option, json_string (value));
161}

References value.

Referenced by get_cont().

Here is the caller graph for this function:

◆ get_cont()

static void get_cont ( struct GNUNET_REST_RequestHandle con_handle,
const char *  url,
void *  cls 
)
static

Handle rest request.

Parameters
handlethe lookup handle

Definition at line 170 of file config_plugin.c.

173{
174 struct MHD_Response *resp;
175 struct RequestHandle *handle = cls;
176 const char *section;
177 char *response;
178 json_t *result;
179
180 if (strlen (GNUNET_REST_API_NS_CONFIG) > strlen (handle->url))
181 {
182 handle->response_code = MHD_HTTP_BAD_REQUEST;
184 return;
185 }
186 if (strlen (GNUNET_REST_API_NS_CONFIG) == strlen (handle->url))
187 {
188 result = json_object ();
190 }
191 else
192 {
193 result = json_object ();
194 section = &handle->url[strlen (GNUNET_REST_API_NS_CONFIG) + 1];
196 section,
198 result);
199 }
200 response = json_dumps (result, 0);
202 GNUNET_assert (MHD_NO != MHD_add_response_header (resp,
203 "Content-Type",
204 "application/json"));
205 handle->proc (handle->proc_cls, resp, MHD_HTTP_OK);
208 json_decref (result);
209}
static void add_section_contents(void *cls, const char *section, const char *option, const char *value)
const struct GNUNET_CONFIGURATION_Handle * config_cfg
Definition: config_plugin.c:44
#define GNUNET_REST_API_NS_CONFIG
Definition: config_plugin.c:34
static void add_sections(void *cls, const char *section, const char *option, const char *value)
static void do_error(void *cls)
Task run on shutdown.
static struct MHD_Response * response
Our canonical response.
static int result
Global testing status.
void GNUNET_CONFIGURATION_iterate(const struct GNUNET_CONFIGURATION_Handle *cfg, GNUNET_CONFIGURATION_Iterator iter, void *iter_cls)
Iterate over all options in the configuration.
void GNUNET_CONFIGURATION_iterate_section_values(const struct GNUNET_CONFIGURATION_Handle *cfg, const char *section, GNUNET_CONFIGURATION_Iterator iter, void *iter_cls)
Iterate over values of a section in the configuration.
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_now(GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run as soon as possible.
Definition: scheduler.c:1303
@ MHD_HTTP_BAD_REQUEST
Bad Request [RFC7231, Section 6.5.1].
@ MHD_HTTP_OK
OK [RFC7231, Section 6.3.1].

References add_section_contents(), add_sections(), cleanup_handle(), config_cfg, do_error(), GNUNET_assert, GNUNET_CONFIGURATION_iterate(), GNUNET_CONFIGURATION_iterate_section_values(), GNUNET_free, GNUNET_REST_API_NS_CONFIG, GNUNET_REST_create_response(), GNUNET_SCHEDULER_add_now(), handle, MHD_HTTP_BAD_REQUEST, MHD_HTTP_OK, response, and result.

Referenced by REST_config_process_request().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ set_value()

static struct GNUNET_CONFIGURATION_Handle * set_value ( struct GNUNET_CONFIGURATION_Handle config,
const char *  section,
const char *  option,
json_t *  value 
)
static

Definition at line 213 of file config_plugin.c.

217{
218 if (json_is_string (value))
220 json_string_value (value));
221 else if (json_is_number (value))
223 json_integer_value (value));
224 else if (json_is_null (value))
225 GNUNET_CONFIGURATION_set_value_string (config, section, option, NULL);
226 else if (json_is_true (value))
227 GNUNET_CONFIGURATION_set_value_string (config, section, option, "yes");
228 else if (json_is_false (value))
229 GNUNET_CONFIGURATION_set_value_string (config, section, option, "no");
230 else
231 return NULL;
232 return config; // for error handling (0 -> success, 1 -> error)
233}
const struct GNUNET_CONFIGURATION_Handle * config
void GNUNET_CONFIGURATION_set_value_string(struct GNUNET_CONFIGURATION_Handle *cfg, const char *section, const char *option, const char *value)
Set a configuration value that should be a string.
void GNUNET_CONFIGURATION_set_value_number(struct GNUNET_CONFIGURATION_Handle *cfg, const char *section, const char *option, unsigned long long number)
Set a configuration value that should be a number.

References config, GNUNET_CONFIGURATION_set_value_number(), GNUNET_CONFIGURATION_set_value_string(), and value.

Referenced by set_cont().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ set_cont()

static void set_cont ( struct GNUNET_REST_RequestHandle con_handle,
const char *  url,
void *  cls 
)
static

Handle REST POST request.

Parameters
handlethe lookup handle

Definition at line 242 of file config_plugin.c.

245{
246 struct RequestHandle *handle = cls;
247 char term_data[handle->rest_handle->data_size + 1];
249 );
250
251 json_error_t err;
252 json_t *data_json;
253 const char *section;
254 const char *option;
255 json_t *sec_obj;
256 json_t *value;
257 char *cfg_fn;
258
259 // invalid url
260 if (strlen (GNUNET_REST_API_NS_CONFIG) > strlen (handle->url))
261 {
262 handle->response_code = MHD_HTTP_BAD_REQUEST;
264 return;
265 }
266
267 // extract data from handle
268 term_data[handle->rest_handle->data_size] = '\0';
269 GNUNET_memcpy (term_data,
270 handle->rest_handle->data,
271 handle->rest_handle->data_size);
272 data_json = json_loads (term_data, JSON_DECODE_ANY, &err);
273
274 if (NULL == data_json)
275 {
277 "Unable to parse JSON Object from %s\n",
278 term_data);
280 return;
281 }
282
283 // POST /config => {<section> : {<option> : <value>}}
284 if (strlen (GNUNET_REST_API_NS_CONFIG) == strlen (handle->url)) // POST /config
285 {
286 // iterate over sections
287 json_object_foreach (data_json, section, sec_obj)
288 {
289 // iterate over options
290 json_object_foreach (sec_obj, option, value)
291 {
292 out = set_value (out, section, option, value);
293 if (NULL == out)
294 {
295 handle->response_code = MHD_HTTP_BAD_REQUEST;
297 json_decref (data_json);
298 return;
299 }
300 }
301 }
302 }
303 else // POST /config/<section> => {<option> : <value>}
304 {
305 // extract the "<section>" part from the url
306 section = &handle->url[strlen (GNUNET_REST_API_NS_CONFIG) + 1];
307 // iterate over options
308 json_object_foreach (data_json, option, value)
309 {
310 out = set_value (out, section, option, value);
311 if (NULL == out)
312 {
313 handle->response_code = MHD_HTTP_BAD_REQUEST;
315 json_decref (data_json);
316 return;
317 }
318 }
319 }
320 json_decref (data_json);
321
322
323 // get cfg file path
324 cfg_fn = NULL;
325 {
326 const char *xdg = getenv ("XDG_CONFIG_HOME");
327 if (NULL != xdg)
328 GNUNET_asprintf (&cfg_fn,
329 "%s%s%s",
330 xdg,
333 else
334 cfg_fn = GNUNET_strdup (GNUNET_OS_project_data_get ()->user_config_file);
335
336 }
337 GNUNET_CONFIGURATION_write (out, cfg_fn);
338 config_cfg = out;
339 handle->proc (handle->proc_cls,
342 GNUNET_free (cfg_fn);
344}
static struct GNUNET_CONFIGURATION_Handle * set_value(struct GNUNET_CONFIGURATION_Handle *config, const char *section, const char *option, json_t *value)
char * getenv()
static char * config_file
Set to the name of the config file used.
Definition: gnunet-arm.c:83
struct GNUNET_CONFIGURATION_Handle * GNUNET_CONFIGURATION_dup(const struct GNUNET_CONFIGURATION_Handle *cfg)
Duplicate an existing configuration object.
enum GNUNET_GenericReturnValue GNUNET_CONFIGURATION_write(struct GNUNET_CONFIGURATION_Handle *cfg, const char *filename)
Write configuration file.
#define GNUNET_memcpy(dst, src, n)
Call memcpy() but check for n being 0 first.
@ GNUNET_ERROR_TYPE_ERROR
int int GNUNET_asprintf(char **buf, const char *format,...) __attribute__((format(printf
Like asprintf, just portable.
#define GNUNET_strdup(a)
Wrapper around GNUNET_xstrdup_.
const struct GNUNET_OS_ProjectData * GNUNET_OS_project_data_get(void)
#define DIR_SEPARATOR_STR
Definition: platform.h:166

References cleanup_handle(), config_cfg, config_file, DIR_SEPARATOR_STR, do_error(), getenv(), GNUNET_asprintf(), GNUNET_CONFIGURATION_dup(), GNUNET_CONFIGURATION_write(), GNUNET_ERROR_TYPE_ERROR, GNUNET_free, GNUNET_log, GNUNET_memcpy, GNUNET_OS_project_data_get(), GNUNET_REST_API_NS_CONFIG, GNUNET_REST_create_response(), GNUNET_SCHEDULER_add_now(), GNUNET_strdup, handle, MHD_HTTP_BAD_REQUEST, MHD_HTTP_OK, set_value(), and value.

Referenced by REST_config_process_request().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ options_cont()

static void options_cont ( struct GNUNET_REST_RequestHandle con_handle,
const char *  url,
void *  cls 
)
static

Handle rest request.

Parameters
handlethe lookup handle

Definition at line 353 of file config_plugin.c.

356{
357 struct MHD_Response *resp;
358 struct RequestHandle *handle = cls;
359
360 resp = GNUNET_REST_create_response (NULL);
361 GNUNET_assert (MHD_NO != MHD_add_response_header (resp,
362 "Access-Control-Allow-Methods",
363 MHD_HTTP_METHOD_GET));
364 handle->proc (handle->proc_cls, resp, MHD_HTTP_OK);
366}

References cleanup_handle(), GNUNET_assert, GNUNET_REST_create_response(), handle, and MHD_HTTP_OK.

Referenced by REST_config_process_request().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ REST_config_process_request()

enum GNUNET_GenericReturnValue REST_config_process_request ( void *  plugin,
struct GNUNET_REST_RequestHandle conndata_handle,
GNUNET_REST_ResultProcessor  proc,
void *  proc_cls 
)

Function processing the REST call.

Parameters
methodHTTP method
urlURL of the HTTP request
databody of the HTTP request (optional)
data_sizelength of the body
proccallback function for the result
proc_clsclosure for proc
Returns
GNUNET_OK if request accepted

Definition at line 370 of file config_plugin.c.

374{
375 struct RequestHandle *handle = GNUNET_new (struct RequestHandle);
377 static const struct GNUNET_REST_RequestHandler handlers[] = {
378 { MHD_HTTP_METHOD_GET, GNUNET_REST_API_NS_CONFIG, &get_cont },
379 { MHD_HTTP_METHOD_POST, GNUNET_REST_API_NS_CONFIG, &set_cont },
380 { MHD_HTTP_METHOD_OPTIONS, GNUNET_REST_API_NS_CONFIG, &options_cont },
382 };
383 (void) plugin;
384
385 handle->proc_cls = proc_cls;
386 handle->proc = proc;
387 handle->rest_handle = conndata_handle;
388 handle->url = GNUNET_strdup (conndata_handle->url);
389 if (handle->url[strlen (handle->url) - 1] == '/')
390 handle->url[strlen (handle->url) - 1] = '\0';
393 handle);
394 if (GNUNET_NO ==
395 GNUNET_REST_handle_request (conndata_handle, handlers, &err, handle))
396 {
398 return GNUNET_NO;
399 }
400 return GNUNET_YES;
401}
struct GNUNET_MQ_MessageHandlers handlers[]
Definition: 003.c:1
static void options_cont(struct GNUNET_REST_RequestHandle *con_handle, const char *url, void *cls)
Handle rest request.
static void set_cont(struct GNUNET_REST_RequestHandle *con_handle, const char *url, void *cls)
Handle REST POST request.
static void get_cont(struct GNUNET_REST_RequestHandle *con_handle, const char *url, void *cls)
Handle rest request.
static struct GNUNET_TESTING_PluginFunctions * plugin
Plugin to dynamically load a test case.
#define GNUNET_CONTAINER_DLL_insert(head, tail, element)
Insert an element at the head of a DLL.
@ GNUNET_YES
@ GNUNET_NO
#define GNUNET_new(type)
Allocate a struct or union of the given type.
int GNUNET_REST_handle_request(struct GNUNET_REST_RequestHandle *conn, const struct GNUNET_REST_RequestHandler *handlers, struct GNUNET_REST_RequestHandlerError *err, void *cls)
Definition: rest.c:64
#define GNUNET_REST_HANDLER_END
const char * url
The url as string.
void(* proc)(struct GNUNET_REST_RequestHandle *handle, const char *url, void *cls)
Namespace to handle.

References cleanup_handle(), get_cont(), GNUNET_CONTAINER_DLL_insert, GNUNET_new, GNUNET_NO, GNUNET_REST_API_NS_CONFIG, GNUNET_REST_handle_request(), GNUNET_REST_HANDLER_END, GNUNET_strdup, GNUNET_YES, handle, handlers, options_cont(), plugin, GNUNET_REST_RequestHandler::proc, requests_head, requests_tail, set_cont(), and GNUNET_REST_RequestHandle::url.

Referenced by run().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ REST_config_done()

void REST_config_done ( struct GNUNET_REST_Plugin api)

Exit point from the plugin.

Parameters
clsthe plugin context (as returned by "init")
Returns
always NULL

Definition at line 405 of file config_plugin.c.

406{
407 struct Plugin *plugin;
408
409 while (NULL != requests_head)
411 plugin = api->cls;
412 plugin->cfg = NULL;
414 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "CONFIG REST plugin is finished\n");
415}
void * cls
Closure for all of the callbacks.
Handle for a plugin.
Definition: block.c:38
struct GNUNET_BLOCK_PluginFunctions * api
Plugin API.
Definition: block.c:47

References Plugin::api, cleanup_handle(), GNUNET_BLOCK_PluginFunctions::cls, GNUNET_ERROR_TYPE_DEBUG, GNUNET_free, GNUNET_log, plugin, and requests_head.

Referenced by do_shutdown().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ REST_config_init()

void * REST_config_init ( const struct GNUNET_CONFIGURATION_Handle c)

Entry point for the plugin.

Parameters
clsthe "struct GNUNET_NAMESTORE_PluginEnvironment*"
Returns
NULL on error, otherwise the plugin context

Definition at line 425 of file config_plugin.c.

426{
427 static struct Plugin plugin;
428 struct GNUNET_REST_Plugin *api;
429
430 config_cfg = c;
431
432 memset (&plugin, 0, sizeof(struct Plugin));
433 plugin.cfg = c;
434 api = GNUNET_new (struct GNUNET_REST_Plugin);
435 api->cls = &plugin;
437 GNUNET_log (GNUNET_ERROR_TYPE_INFO, _ ("CONFIG REST API initialized\n"));
438 return api;
439}
@ GNUNET_ERROR_TYPE_INFO
#define _(String)
GNU gettext support macro.
Definition: platform.h:178
struct returned by the initialization function of the plugin
void * cls
The closure of the plugin.
const char * name
Plugin name.

References _, GNUNET_REST_Plugin::cls, config_cfg, GNUNET_ERROR_TYPE_INFO, GNUNET_log, GNUNET_new, GNUNET_REST_API_NS_CONFIG, GNUNET_REST_Plugin::name, and plugin.

Referenced by run().

Here is the caller graph for this function:

Variable Documentation

◆ config_cfg

const struct GNUNET_CONFIGURATION_Handle* config_cfg

Definition at line 44 of file config_plugin.c.

Referenced by get_cont(), REST_config_init(), and set_cont().

◆ requests_head

struct RequestHandle* requests_head
static

DLL.

Definition at line 88 of file config_plugin.c.

Referenced by cleanup_handle(), REST_config_done(), and REST_config_process_request().

◆ requests_tail

struct RequestHandle* requests_tail
static

DLL.

Definition at line 93 of file config_plugin.c.

Referenced by cleanup_handle(), and REST_config_process_request().