rest controller update

This commit is contained in:
2018-04-25 00:04:47 +02:00
parent a539a82792
commit 3d48295a46
8 changed files with 199 additions and 17 deletions

View File

@@ -25,6 +25,7 @@ file (
${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/core/ubus-connection.cpp ${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/core/ubus-connection.cpp
${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/core/ubus-reason.cpp ${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/core/ubus-reason.cpp
# rest # rest
${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/rest/ubus.cpp
${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/rest/rest-controller.cpp ${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/rest/rest-controller.cpp
${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/rest/rest-connection.cpp ${workspaceRoot}/src/plugins/uhttpd/uhttpd-rest-api/rest/rest-connection.cpp
#etag-rest #etag-rest

View File

@@ -26,6 +26,17 @@
#include "core/web-controller.h" #include "core/web-controller.h"
/*! ----------------------------------------------------------------------------
* @fn WebController
*
* @brief default constructor of the web controller object.
*/
WebController::WebController(void)
{
}
/*! ---------------------------------------------------------------------------- /*! ----------------------------------------------------------------------------
* @fn WebController * @fn WebController
* *

View File

@@ -40,6 +40,7 @@ struct client;
class WebController class WebController
{ {
public: public:
WebController(void);
WebController(const std::string &a_path); WebController(const std::string &a_path);
virtual ~WebController(void); virtual ~WebController(void);

View File

@@ -22,22 +22,43 @@
/*------------------------------- INCLUDES ----------------------------------*/ /*------------------------------- INCLUDES ----------------------------------*/
#include <json-c/json.h>
#include "rest/rest-connection.h" #include "rest/rest-connection.h"
#include "rest/rest-controller.h" #include "rest/rest-controller.h"
#include <uhttpd/uhttpd.h> #include <uhttpd/uhttpd.h>
#define kControllerModelKey "model"
#define kControllerEndpointKey "endpoint"
#define kControllerUbusKey "ubus"
#define kControllerPathKey "path"
#define kControllerMethodKey "method"
/*! ---------------------------------------------------------------------------- /*! ----------------------------------------------------------------------------
* @fn RestController * @fn RestController
* *
* @brief constructor of the rest controller object. * @brief constructor of the rest controller object.
*/ */
RestController::RestController(const std::string &a_path, const std::string &a_method_get, const std::string &a_method_put, int a_timeout, bool a_raw_response) : WebController(a_path), RestController::RestController(void)
{
}
/*! ----------------------------------------------------------------------------
* @fn RestController
*
* @brief constructor of the rest controller object.
*/
RestController::RestController(const std::string &a_path, const std::string &a_method_get, const std::string &a_method_put, int a_timeout, bool a_raw_response) : WebController(a_path)
#if 0
m_method_get(a_method_get), m_method_get(a_method_get),
m_method_put(a_method_put), m_method_put(a_method_put),
m_timeout(a_timeout), m_timeout(a_timeout),
mf_raw_response(a_raw_response) mf_raw_response(a_raw_response)
#endif
{ {
} }
@@ -60,6 +81,67 @@ WebConnection *RestController::new_connection(struct uhttpd_ops *an_ops, struct
return new RestConnection(an_ops, a_client, this, a_parameters); return new RestConnection(an_ops, a_client, this, a_parameters);
} }
/*! ----------------------------------------------------------------------------
* @fn from_json
*
* @brief import a rest controller from a json node..
*/
bool RestController::from_json(struct json_object *a_node)
{
struct json_object *the_value_node, *the_ubus_node;
// model
if (json_object_object_get_ex(a_node, kControllerModelKey, &the_value_node))
{
std::string the_model;
the_model = json_object_get_string(the_value_node);
if (the_model == "get")
m_method = UH_HTTP_MSG_GET;
else if (the_model == "put")
m_method = UH_HTTP_MSG_PUT;
else if (the_model == "post")
m_method = UH_HTTP_MSG_POST;
else
m_method = UH_HTTP_MSG_DELETE;
}
// endpoint
if (json_object_object_get_ex(a_node, kControllerEndpointKey, &the_value_node))
{
int the_len, i;
struct json_object *the_ep_node;
the_len = json_object_array_length(the_value_node);
for (i = 0; i < the_len; i++)
{
std::string the_endpoint;
the_ep_node = json_object_array_get_idx(the_value_node, i);
the_endpoint = json_object_get_string(the_ep_node);
m_endpoint.push_back(the_endpoint);
}
}
// ubus
if (json_object_object_get_ex(a_node, kControllerUbusKey, &the_ubus_node))
{
// path
if (json_object_object_get_ex(the_ubus_node, kControllerPathKey, &the_value_node))
{
m_ubus.m_path = json_object_get_string(the_value_node);
}
//method
if (json_object_object_get_ex(the_ubus_node, kControllerMethodKey, &the_value_node))
{
m_ubus.m_method = json_object_get_string(the_value_node);
}
}
return true;
}
/*! ---------------------------------------------------------------------------- /*! ----------------------------------------------------------------------------
* @fn get_method_get * @fn get_method_get
* *
@@ -67,7 +149,7 @@ WebConnection *RestController::new_connection(struct uhttpd_ops *an_ops, struct
*/ */
std::string RestController::get_method_get(void) std::string RestController::get_method_get(void)
{ {
return m_method_get; return ""; //m_method_get;
} }
/*! ---------------------------------------------------------------------------- /*! ----------------------------------------------------------------------------
@@ -77,7 +159,7 @@ std::string RestController::get_method_get(void)
*/ */
std::string RestController::get_method_put(void) std::string RestController::get_method_put(void)
{ {
return m_method_put; return ""; //m_method_put;
} }
/*! ---------------------------------------------------------------------------- /*! ----------------------------------------------------------------------------
@@ -87,7 +169,7 @@ std::string RestController::get_method_put(void)
*/ */
uint16_t RestController::get_timeout(void) uint16_t RestController::get_timeout(void)
{ {
return m_timeout; return 0; //m_timeout;
} }
/*! ---------------------------------------------------------------------------- /*! ----------------------------------------------------------------------------
@@ -97,7 +179,7 @@ uint16_t RestController::get_timeout(void)
*/ */
bool RestController::is_raw_response(void) bool RestController::is_raw_response(void)
{ {
return mf_raw_response; return false; //mf_raw_response;
} }
/*! ---------------------------------------------------------------------------- /*! ----------------------------------------------------------------------------
@@ -107,6 +189,7 @@ bool RestController::is_raw_response(void)
*/ */
std::string RestController::get_method(uint8_t a_method) std::string RestController::get_method(uint8_t a_method)
{ {
#if 0
switch (a_method) switch (a_method)
{ {
case UH_HTTP_MSG_GET: case UH_HTTP_MSG_GET:
@@ -120,6 +203,6 @@ std::string RestController::get_method(uint8_t a_method)
// TODO ERROR // TODO ERROR
break; break;
}; };
#endif
return ""; return "";
} }

View File

@@ -27,8 +27,11 @@
#include <stdint.h> #include <stdint.h>
#include <string> #include <string>
#include <vector>
#include <core/web-controller.h> #include <core/web-controller.h>
#include <rest/ubus.h>
/*--------------------------------- Define ----------------------------------*/ /*--------------------------------- Define ----------------------------------*/
@@ -38,16 +41,21 @@
/*----------------------------- Dependencies --------------------------------*/ /*----------------------------- Dependencies --------------------------------*/
struct json_object;
/*--------------------------------- CLASS ----------------------------------*/ /*--------------------------------- CLASS ----------------------------------*/
class RestController : public WebController class RestController : public WebController
{ {
public: public:
RestController(void);
RestController(const std::string &a_path, const std::string &a_method_get = "", const std::string &a_method_put = "", int a_timeout = kDefaultTimeout, bool a_raw_response = false); RestController(const std::string &a_path, const std::string &a_method_get = "", const std::string &a_method_put = "", int a_timeout = kDefaultTimeout, bool a_raw_response = false);
virtual ~RestController(void); virtual ~RestController(void);
WebConnection *new_connection(struct uhttpd_ops *an_ops, struct client *a_client, const std::string &a_parameters); WebConnection *new_connection(struct uhttpd_ops *an_ops, struct client *a_client, const std::string &a_parameters);
bool from_json(struct json_object *a_node);
std::string get_method_get(void); std::string get_method_get(void);
std::string get_method_put(void); std::string get_method_put(void);
uint16_t get_timeout(void); uint16_t get_timeout(void);
@@ -56,12 +64,18 @@ class RestController : public WebController
std::string get_method(uint8_t a_method); std::string get_method(uint8_t a_method);
protected: protected:
uint8_t m_method;
std::vector<std::string> m_endpoint;
Ubus m_ubus;
/*
std::string m_name; std::string m_name;
std::string m_path; std::string m_path;
std::string m_method_get; std::string m_method_get;
std::string m_method_put; std::string m_method_put;
uint16_t m_timeout; uint16_t m_timeout;
bool mf_raw_response; bool mf_raw_response;
*/
}; };
#endif /* _REST_CONTROLLER_H */ #endif /* _REST_CONTROLLER_H */

View File

@@ -0,0 +1,34 @@
/*!
* Copyright (c) 2015-2018, NADAL Jean-Baptiste. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* @Author: NADAL Jean-Baptiste
* @Date: 24/04/2018
*/
/*------------------------------- INCLUDES ----------------------------------*/
#include "ubus.h"
/*! ----------------------------------------------------------------------------
* @fn Ubus
*
* @brief constructor of the ubus object.
*/
Ubus::Ubus(void)
{
}

View File

@@ -0,0 +1,41 @@
/*!
* Copyright (c) 2015-2018, NADAL Jean-Baptiste. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* @Author: NADAL Jean-Baptiste
* @Date: 24/04/2018
*/
#ifndef _UBUS_H
#define _UBUS_H
/*------------------------------- INCLUDES ----------------------------------*/
#include <string>
/*--------------------------------- CLASS ----------------------------------*/
class Ubus
{
public:
Ubus(void);
std::string m_path;
std::string m_method;
};
#endif /* _UBUS_H */

View File

@@ -425,7 +425,7 @@ int UhttpServer::load_config_dir(const char *a_config_dir_path)
struct json_object *the_root_node; struct json_object *the_root_node;
the_rep = opendir(a_config_dir_path); the_rep = opendir(a_config_dir_path);
if (the_rep == NULL) { if (the_rep == NULL) {
fprintf (stderr, "Impossible to open the config directory. check your parameters.\n"); fprintf (stderr, "Impossible to open the config directory (%s).\n", a_config_dir_path);
return -1; return -1;
} }
while ((the_dir_ent = readdir(the_rep)) != NULL) while ((the_dir_ent = readdir(the_rep)) != NULL)
@@ -469,22 +469,18 @@ int UhttpServer::add_controller_from_json(struct json_object *a_root_node)
if (json_object_object_get_ex(a_root_node, kControllerKey, &the_ctr_array_node)) if (json_object_object_get_ex(a_root_node, kControllerKey, &the_ctr_array_node))
{ {
RestController *the_rest_controller;
the_len = json_object_array_length(the_ctr_array_node); the_len = json_object_array_length(the_ctr_array_node);
for (i = 0; i < the_len; i++) for (i = 0; i < the_len; i++)
{ {
the_ctrl_node = json_object_array_get_idx(the_ctr_array_node, i); the_ctrl_node = json_object_array_get_idx(the_ctr_array_node, i);
the_rest_controller = new RestController;
if (get_controller_fields(the_ctrl_node, the_path, the_model_name, the_event_name, the_etag_key, the_get_method, the_set_method, the_raw_response))
if (the_rest_controller->from_json(the_ctrl_node))
{ {
#if 0 //new RestController(the_model_name, the_get_method, the_set_method, kDefaultTimeout, the_raw_response)
printf("Path: <%s>\n", the_path.c_str()); add_controller(the_path, the_rest_controller);
printf("\t- model name: <%s>\n", the_model_name.c_str());
printf("\t- get: <%s>\n", the_get_method.c_str());
printf("\t- set: <%s>\n", the_set_method.c_str());
printf("\t- raw response: <%s>\n", the_raw_response?"true":"false");
#endif
add_controller(the_path, new RestController(the_model_name, the_get_method, the_set_method, kDefaultTimeout, the_raw_response));
} }
} }
} }
@@ -535,6 +531,7 @@ bool UhttpServer::get_controller_fields(struct json_object *a_node, std::string
std::string &a_get_method, std::string &a_set_method, bool &a_raw_response) std::string &a_get_method, std::string &a_set_method, bool &a_raw_response)
{ {
bool the_result = false; bool the_result = false;
struct json_object *the_path_node, *the_ubus_model_node, *the_ubus_event_node, *the_get_method_node, *the_etag_key_node; struct json_object *the_path_node, *the_ubus_model_node, *the_ubus_event_node, *the_get_method_node, *the_etag_key_node;
struct json_object *the_set_method_node, *the_raw_response_node; struct json_object *the_set_method_node, *the_raw_response_node;