/* * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The OpenAirInterface Software Alliance licenses this file to You under * the OAI Public License, Version 1.1 (the "License"); you may not use this * file except in compliance with the License. You may obtain a copy of the * License at * * http://www.openairinterface.org/?page_id=698 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *------------------------------------------------------------------------------- * For more information about the OpenAirInterface (OAI) Software Alliance: * contact@openairinterface.org */ /** * 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 "AuthenticationStatusDocumentApi.h" #include "Helpers.h" #include "logger.hpp" namespace oai::udr::api { using namespace oai::udr::helpers; using namespace oai::udr::model; AuthenticationStatusDocumentApi::AuthenticationStatusDocumentApi( std::shared_ptr rtr) { router = rtr; } void AuthenticationStatusDocumentApi::init() { setupRoutes(); } void AuthenticationStatusDocumentApi::setupRoutes() { using namespace Pistache::Rest; Routes::Put( *router, base + "/subscription-data/:ueId/authentication-data/authentication-status", Routes::bind(&AuthenticationStatusDocumentApi:: create_authentication_status_handler, this)); Routes::Delete( *router, base + "/subscription-data/:ueId/authentication-data/authentication-status", Routes::bind(&AuthenticationStatusDocumentApi:: delete_authentication_status_handler, this)); Routes::Get( *router, base + "/subscription-data/:ueId/authentication-data/authentication-status", Routes::bind( &AuthenticationStatusDocumentApi::query_authentication_status_handler, this)); // Default handler, called when a route is not found router->addCustomHandler( Routes::bind(&AuthenticationStatusDocumentApi:: authentication_status_document_api_default_handler, this)); } void AuthenticationStatusDocumentApi::create_authentication_status_handler( const Pistache::Rest::Request &request, Pistache::Http::ResponseWriter response) { // Getting the path params auto ueId = request.param(":ueId").as(); // Getting the body param AuthEvent authEvent; try { nlohmann::json::parse(request.body()).get_to(authEvent); this->create_authentication_status(ueId, authEvent, 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(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 AuthenticationStatusDocumentApi::delete_authentication_status_handler( const Pistache::Rest::Request &request, Pistache::Http::ResponseWriter response) { // Getting the path params auto ueId = request.param(":ueId").as(); try { this->delete_authentication_status(ueId, 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(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 AuthenticationStatusDocumentApi::query_authentication_status_handler( const Pistache::Rest::Request &request, Pistache::Http::ResponseWriter response) { // Getting the path params auto ueId = request.param(":ueId").as(); // Getting the query params auto fieldsQuery = request.query().get("fields"); Pistache::Optional> fields; if (!fieldsQuery.isEmpty()) { std::vector valueQuery_instance; if (fromStringValue(fieldsQuery.get(), valueQuery_instance)) { fields = Pistache::Some(valueQuery_instance); } } auto supportedFeaturesQuery = request.query().get("supported-features"); Pistache::Optional supportedFeatures; if (!supportedFeaturesQuery.isEmpty()) { std::string valueQuery_instance; if (fromStringValue(supportedFeaturesQuery.get(), valueQuery_instance)) { supportedFeatures = Pistache::Some(valueQuery_instance); } } try { this->query_authentication_status(ueId, fields, 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(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 AuthenticationStatusDocumentApi:: authentication_status_document_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 oai::udr::api