2020-08-25 20:27:26 +02:00
|
|
|
/** The "path" API ressource.
|
|
|
|
*
|
2022-03-15 09:18:01 -04:00
|
|
|
* @author Steffen Vogel <svogel2@eonerc.rwth-aachen.de>
|
2022-03-15 09:28:57 -04:00
|
|
|
* @copyright 2014-2022, Institute for Automation of Complex Power Systems, EONERC
|
2022-07-04 18:20:03 +02:00
|
|
|
* @license Apache 2.0
|
2020-08-25 20:27:26 +02:00
|
|
|
*********************************************************************************/
|
|
|
|
|
|
|
|
#include <jansson.h>
|
|
|
|
#include <uuid/uuid.h>
|
|
|
|
|
|
|
|
#include <villas/super_node.hpp>
|
2021-08-10 10:12:48 -04:00
|
|
|
#include <villas/path.hpp>
|
2020-08-25 20:27:26 +02:00
|
|
|
#include <villas/utils.hpp>
|
|
|
|
#include <villas/stats.hpp>
|
|
|
|
#include <villas/api/session.hpp>
|
2022-03-25 17:27:16 +01:00
|
|
|
#include <villas/api/requests/path.hpp>
|
2020-08-25 20:27:26 +02:00
|
|
|
#include <villas/api/response.hpp>
|
|
|
|
|
|
|
|
namespace villas {
|
|
|
|
namespace node {
|
|
|
|
namespace api {
|
|
|
|
|
|
|
|
class PathInfoRequest : public PathRequest {
|
|
|
|
|
|
|
|
public:
|
|
|
|
using PathRequest::PathRequest;
|
|
|
|
|
|
|
|
virtual Response * execute()
|
|
|
|
{
|
2020-09-30 17:56:12 +02:00
|
|
|
if (method != Session::Method::GET)
|
2020-08-25 20:27:26 +02:00
|
|
|
throw InvalidMethod(this);
|
|
|
|
|
|
|
|
if (body != nullptr)
|
|
|
|
throw BadRequest("Endpoint does not accept any body data");
|
|
|
|
|
2021-08-10 10:12:48 -04:00
|
|
|
return new JsonResponse(session, HTTP_STATUS_OK, path->toJson());
|
2020-08-25 20:27:26 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Register API request */
|
|
|
|
static char n[] = "path";
|
2020-09-10 11:12:49 +02:00
|
|
|
static char r[] = "/path/(" RE_UUID ")";
|
2020-08-25 20:27:26 +02:00
|
|
|
static char d[] = "retrieve info of a path";
|
|
|
|
static RequestPlugin<PathInfoRequest, n, r, d> p;
|
|
|
|
|
|
|
|
} /* namespace api */
|
|
|
|
} /* namespace node */
|
|
|
|
} /* namespace villas */
|