/** * Nudr_DataRepository API OpenAPI file * Unified Data Repository Service. © 2020, 3GPP Organizational Partners (ARIB, * ATIS, CCSA, ETSI, TSDSI, TTA, TTC). All rights reserved. * * The version of the OpenAPI document: 2.1.2 * * * NOTE: This class is auto generated by OpenAPI Generator * (https://openapi-generator.tech). https://openapi-generator.tech Do not edit * the class manually. */ #include "EventExposureGroupSubscriptionsCollectionApi.h" #include "Helpers.h" namespace org { namespace openapitools { namespace server { namespace api { using namespace org::openapitools::server::helpers; using namespace org::openapitools::server::model; EventExposureGroupSubscriptionsCollectionApi:: EventExposureGroupSubscriptionsCollectionApi( std::shared_ptr<Pistache::Rest::Router> rtr) { router = rtr; } void EventExposureGroupSubscriptionsCollectionApi::init() { setupRoutes(); } void EventExposureGroupSubscriptionsCollectionApi::setupRoutes() { using namespace Pistache::Rest; Routes::Post(*router, base + "/subscription-data/group-data/:ueGroupId/ee-subscriptions", Routes::bind(&EventExposureGroupSubscriptionsCollectionApi:: create_ee_group_subscriptions_handler, this)); Routes::Get(*router, base + "/subscription-data/group-data/:ueGroupId/ee-subscriptions", Routes::bind(&EventExposureGroupSubscriptionsCollectionApi:: query_ee_group_subscriptions_handler, this)); // Default handler, called when a route is not found router->addCustomHandler(Routes::bind( &EventExposureGroupSubscriptionsCollectionApi:: event_exposure_group_subscriptions_collection_api_default_handler, this)); } void EventExposureGroupSubscriptionsCollectionApi:: create_ee_group_subscriptions_handler( const Pistache::Rest::Request &request, Pistache::Http::ResponseWriter response) { // Getting the path params auto ueGroupId = request.param(":ueGroupId").as<std::string>(); // Getting the body param EeSubscription eeSubscription; try { nlohmann::json::parse(request.body()).get_to(eeSubscription); this->create_ee_group_subscriptions(ueGroupId, eeSubscription, response); } catch (nlohmann::detail::exception &e) { // send a 400 error response.send(Pistache::Http::Code::Bad_Request, e.what()); return; } catch (Pistache::Http::HttpError &e) { response.send(static_cast<Pistache::Http::Code>(e.code()), e.what()); return; } catch (std::exception &e) { // send a 500 error response.send(Pistache::Http::Code::Internal_Server_Error, e.what()); return; } } void EventExposureGroupSubscriptionsCollectionApi:: query_ee_group_subscriptions_handler( const Pistache::Rest::Request &request, Pistache::Http::ResponseWriter response) { // Getting the path params auto ueGroupId = request.param(":ueGroupId").as<std::string>(); // Getting the query params auto supportedFeaturesQuery = request.query().get("supported-features"); Pistache::Optional<std::string> supportedFeatures; if (!supportedFeaturesQuery.isEmpty()) { std::string valueQuery_instance; if (fromStringValue(supportedFeaturesQuery.get(), valueQuery_instance)) { supportedFeatures = Pistache::Some(valueQuery_instance); } } try { this->query_ee_group_subscriptions(ueGroupId, supportedFeatures, response); } catch (nlohmann::detail::exception &e) { // send a 400 error response.send(Pistache::Http::Code::Bad_Request, e.what()); return; } catch (Pistache::Http::HttpError &e) { response.send(static_cast<Pistache::Http::Code>(e.code()), e.what()); return; } catch (std::exception &e) { // send a 500 error response.send(Pistache::Http::Code::Internal_Server_Error, e.what()); return; } } void EventExposureGroupSubscriptionsCollectionApi:: event_exposure_group_subscriptions_collection_api_default_handler( const Pistache::Rest::Request &, Pistache::Http::ResponseWriter response) { response.send(Pistache::Http::Code::Not_Found, "The requested method does not exist"); } } // namespace api } // namespace server } // namespace openapitools } // namespace org