/* The "paths" API ressource.
 *
 * Author: Steffen Vogel <post@steffenvogel.de>
 * SPDX-FileCopyrightText: 2014-2023 Institute for Automation of Complex Power Systems, RWTH Aachen University
 * SPDX-License-Identifier: Apache-2.0
 */

#include <jansson.h>

#include <villas/api/request.hpp>
#include <villas/api/response.hpp>
#include <villas/api/session.hpp>
#include <villas/hook.hpp>
#include <villas/path.hpp>
#include <villas/super_node.hpp>
#include <villas/utils.hpp>

namespace villas {
namespace node {
namespace api {

class PathsRequest : public Request {

public:
  using Request::Request;

  virtual Response *execute() {
    if (method != Session::Method::GET)
      throw InvalidMethod(this);

    if (body != nullptr)
      throw BadRequest("Paths endpoint does not accept any body data");

    json_t *json_paths = session->getSuperNode()->getPaths().toJson();

    return new JsonResponse(session, HTTP_STATUS_OK, json_paths);
  }
};

// Register API request
static char n[] = "paths";
static char r[] = "/paths";
static char d[] = "Get list of all paths with details";
static RequestPlugin<PathsRequest, n, r, d> p;

} // namespace api
} // namespace node
} // namespace villas