#include "DiameterPort.hh" #include "sip_layer_factory.hh" #include "loggers.hh" namespace LibDiameter__Interface { DiameterPort::DiameterPort(const char *par_port_name): DiameterPort_BASE(par_port_name), _cfg_params(), _layer_params(), _layer(nullptr), _time_key("DiameterPort::outgoing_send") { // Nothing to do } // End of constructor DiameterPort::~DiameterPort() { loggers::get_instance().log(">>> DiameterPort::~DiameterPort"); if (_layer != nullptr) { delete _layer; } } // End of destructor void DiameterPort::set_parameter(const char * parameter_name, const char * parameter_value) { loggers::get_instance().log("DiameterPort::set_parameter: %s=%s", parameter_name, parameter_value); _cfg_params.insert(std::pair(std::string(parameter_name), std::string(parameter_value))); } /*void DiameterPort::Handle_Fd_Event(int fd, boolean is_readable, boolean is_writable, boolean is_error) {}*/ void DiameterPort::Handle_Fd_Event_Error(int /*fd*/) { } void DiameterPort::Handle_Fd_Event_Writable(int /*fd*/) { } void DiameterPort::Handle_Fd_Event_Readable(int /*fd*/) { } /*void DiameterPort::Handle_Timeout(double time_since_last_call) {}*/ void DiameterPort::user_map(const char * system_port) { loggers::get_instance().log(">>> DiameterPort::user_map: %s", system_port); // Build layer stack params::iterator it = _cfg_params.find(std::string("params")); if (it != _cfg_params.end()) { loggers::get_instance().log("DiameterPort::user_map: %s", it->second.c_str()); // Setup parameters params::convert(_layer_params, it->second); // TODO This _layer_params seems to be useless // Create layer _layer = layer_stack_builder::get_instance()->create_layer_stack(it->second.c_str()); if (static_cast(_layer) == nullptr) { loggers::get_instance().error("DiameterPort::user_map: Invalid stack configuration: %s", it->second.c_str()); } static_cast(_layer)->add_upper_port(this); } else { loggers::get_instance().error("DiameterPort::user_map: No layers defined in configuration file"); } } // End of user_map method void DiameterPort::user_unmap(const char * system_port) { loggers::get_instance().log(">>> DiameterPort::user_unmap: %s", system_port); // Reset layers if (_layer != nullptr) { delete _layer; _layer = nullptr; } } // End of user_unmap method void DiameterPort::user_start() { loggers::get_instance().log(">>> DiameterPort::user_start"); } // End of user_start method void DiameterPort::user_stop() { loggers::get_instance().log(">>> DiameterPort::user_stop"); } // End of user_stop method void DiameterPort::receiveMsg (const LibDiameter__SIPTypesAndValues::Request& p_ind, const params& p_params) { loggers::get_instance().log_msg(">>> DiameterPort::receive_msg: ", p_ind); // Sanity check if (!p_ind.is_bound()) { return; } if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::REGISTER__E) { incoming_message(LibDiameter__SIPTypesAndValues::REGISTER__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::INVITE__E) { incoming_message(LibDiameter__SIPTypesAndValues::INVITE__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::SUBSCRIBE__E) { incoming_message(LibDiameter__SIPTypesAndValues::SUBSCRIBE__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::NOTIFY__E) { incoming_message(LibDiameter__SIPTypesAndValues::NOTIFY__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::BYE__E) { incoming_message(LibDiameter__SIPTypesAndValues::BYE__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::INFO__E) { incoming_message(LibDiameter__SIPTypesAndValues::INFO__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::OPTIONS__E) { incoming_message(LibDiameter__SIPTypesAndValues::OPTIONS__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::MESSAGE__E) { incoming_message(LibDiameter__SIPTypesAndValues::MESSAGE__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::CANCEL__E) { incoming_message(LibDiameter__SIPTypesAndValues::CANCEL__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else if (p_ind.requestLine().method() == LibDiameter__SIPTypesAndValues::Method::ACK__E) { incoming_message(LibDiameter__SIPTypesAndValues::ACK__Request(p_ind.requestLine(), p_ind.msgHeader(), p_ind.messageBody(), p_ind.payload())); } else { incoming_message(p_ind); } } // End of method receiveMsg void DiameterPort::receiveMsg (const LibDiameter__SIPTypesAndValues::Response& p_ind, const params& p_params) { loggers::get_instance().log_msg(">>> DiameterPort::receive_msg: ", p_ind); // Sanity check if (!p_ind.is_bound()) { return; } incoming_message(p_ind); } // End of method receiveMsg void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::INVITE__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } // End of outgoing_send void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::ACK__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } // End of outgoing_send void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::REGISTER__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::SUBSCRIBE__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::MESSAGE__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::OPTIONS__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::BYE__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::CANCEL__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::NOTIFY__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::INFO__Request& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } void DiameterPort::outgoing_send(const LibDiameter__SIPTypesAndValues::Response& send_par, const Address4SIP *destination_address) { loggers::get_instance().log_msg(">>> DiameterPort::outgoing_send: ", send_par); float duration; loggers::get_instance().set_start_time(_time_key); params params; static_cast(_layer)->sendMsg(send_par, params); loggers::get_instance().set_stop_time(_time_key, duration); } }