/*! * \file diameter_layer.hh * \brief Header file for ITS HTTP protocol layer. * \author ETSI STF549 * \copyright ETSI Copyright Notification * No part may be reproduced except as authorized by written permission. * The copyright and the foregoing restriction extend to reproduction in all media. * All rights reserved. * \version 0.1 */ #pragma once #include #include "t_layer.hh" namespace LibDiameter__Interface { class DiameterPort; //! Forward declaration of TITAN class } namespace LibDiameter__SIPTypesAndValues { class REGISTER__Request; //! Forward declaration of TITAN class class INVITE__Request; //! Forward declaration of TITAN class class ACK__Request; //! Forward declaration of TITAN class class SUSCRIBE__Request; //! Forward declaration of TITAN class class MESSAGE__Request; //! Forward declaration of TITAN class class OPTIONS__Request; //! Forward declaration of TITAN class class CANCEL__Request; //! Forward declaration of TITAN class class NOTIFY__Request; //! Forward declaration of TITAN class class INFO__Request; //! Forward declaration of TITAN class class BYE__Request; //! Forward declaration of TITAN class class Resquest; //! Forward declaration of TITAN class class Response; //! Forward declaration of TITAN class } class OCTETSTRING; //! Forward declaration of TITAN class /*! * \class diameter_layer * \brief This class provides a factory class to create an diameter_layer class instance */ class diameter_layer : public t_layer { params _params; public: //! \publicsection /*! * \brief Specialised constructor * Create a new instance of the diameter_layer class * \param[in] p_type \todo * \param[in] p_param \todo */ diameter_layer() : t_layer(), _params() {}; /*! * \brief Specialised constructor * Create a new instance of the diameter_layer class * \param[in] p_type \todo * \param[in] p_param \todo */ diameter_layer(const std::string& p_type, const std::string& p_param); /*! * \brief Default destructor */ virtual ~diameter_layer() { }; void sendMsg(const LibDiameter__SIPTypesAndValues::REGISTER__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::INVITE__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::ACK__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::SUBSCRIBE__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::MESSAGE__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::OPTIONS__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::BYE__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::CANCEL__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::NOTIFY__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::INFO__Request& p_diameter_message, params& p_param); void sendMsg(const LibDiameter__SIPTypesAndValues::Response& p_diameter_message, params& p_param); /*! * \virtual * \fn void send_data(OCTETSTRING& data, params& p_params); * \brief Send bytes formated data to the lower layers * \param[in] p_data The data to be sent * \param[in] p_params Some parameters to overwrite default value of the lower layers parameters */ virtual void send_data(OCTETSTRING& data, params& p_params); /*! * \virtual * \fn void receive_data(OCTETSTRING& data, params& p_params); * \brief Receive bytes formated data from the lower layers * \param[in] p_data The bytes formated data received * \param[in] p_params Some lower layers parameters values when data was received */ virtual void receive_data(OCTETSTRING& data, params& info); }; // End of class diameter_layer