btp_layer.cc 3.85 KB
Newer Older
garciay's avatar
garciay committed
#include "btp_types.hh"
garciay's avatar
garciay committed
#include "btp_layer_factory.hh"
#include "loggers.hh"

#include "converter.hh"

garciay's avatar
garciay committed
btp_layer::btp_layer(const std::string & p_type, const std::string & param) : t_layer<LibItsBtp__TestSystem::BtpPort>(p_type), _params(), _codec(), _device_mode{true} {
garciay's avatar
garciay committed
  loggers::get_instance().log(">>> btp_layer::btp_layer: %s, %s", to_string().c_str(), param.c_str());
  // Setup parameters
garciay's avatar
garciay committed
  params::convert(_params, param);
  
  // Sanity check
garciay's avatar
garciay committed
  params::const_iterator it = _params.find(params::btp_type);
  if (it == _params.cend()) {
    _params[params::btp_type] = std::string("btpB");
garciay's avatar
garciay committed
  it = _params.find(params::btp_destination_port);
  if (it == _params.cend()) {
garciay's avatar
garciay committed
    _params[params::btp_destination_port] = std::to_string(2001);
garciay's avatar
garciay committed
  it = _params.find(params::btp_info);
  if (it == _params.cend()) {
garciay's avatar
garciay committed
    _params[params::btp_info] = std::to_string(0);
garciay's avatar
garciay committed
  it = _params.find(params::device_mode);
  if (it != _params.cend()) {
    _device_mode = (1 == converter::get_instance().string_to_int(it->second));
garciay's avatar
garciay committed
void btp_layer::sendMsg(const LibItsBtp__TestSystem::BtpReq& p, params& params){
garciay's avatar
garciay committed
  loggers::get_instance().log(">>> btp_layer::sendMsg");
  params.log();

  // Encode BTP PDU
  OCTETSTRING data;
  _codec.encode(p.msgOut(), data);
garciay's avatar
garciay committed
  send_data(data, params);
garciay's avatar
garciay committed
void btp_layer::send_data(OCTETSTRING& data, params& params) {
garciay's avatar
garciay committed
  loggers::get_instance().log_msg(">>> btp_layer::send_data: ", data);
  params.log(); // TODO To be removed

  if (_device_mode) {
    LibItsBtp__TypesAndValues::BtpHeader header;
    std::string btp_type;
garciay's avatar
garciay committed
    params::const_iterator it = params.find(params::next_header);
    if (it != params.cend()) {
      btp_type = it->second;
    } else {
garciay's avatar
garciay committed
      btp_type = _params[params::btp_type];
    }
    if (btp_type.compare("btpA") == 0) {
      header.btpAHeader() = LibItsBtp__TypesAndValues::BtpAHeader(
garciay's avatar
garciay committed
                                                                  std::stoi(_params[params::btp_destination_port]),
                                                                  std::stoi(_params[params::btp_info])
                                                                  );
    } else {
      header.btpBHeader() = LibItsBtp__TypesAndValues::BtpBHeader(
garciay's avatar
garciay committed
                                                                  std::stoi(_params[params::btp_destination_port]),
                                                                  std::stoi(_params[params::btp_info])
                                                                  );
    }
    LibItsBtp__TypesAndValues::BtpPacket p(
                                           header,
                                           data
                                           );
garciay's avatar
garciay committed
    loggers::get_instance().log_msg("btp_layer::send_data: ", p);
    // Encode BTP PDU
    OCTETSTRING os;
    _codec.encode(p, os);
    data = os;
  }
garciay's avatar
garciay committed
  send_to_all_layers(data, params);
garciay's avatar
garciay committed
void btp_layer::receive_data(OCTETSTRING& data, params& params)
garciay's avatar
garciay committed
  loggers::get_instance().log_msg(">>> btp_layer::receive_data: ", data);
  params.log();  
  // Decode the payload
  LibItsBtp__TestSystem::BtpInd p;
garciay's avatar
garciay committed
  params::const_iterator it = params.find(params::gn_next_header);
  if (it != params.cend()) {
garciay's avatar
garciay committed
    _codec.set_btp_type((it->second.compare("02") == 0) ? btp_codec::btpB : btp_codec::btpA);
  }
  _codec.decode(data, p.msgIn(), &params);
  
  // Pass the BTP raw payload to the upper layers if any
garciay's avatar
garciay committed
  it = params.find(params::btp_payload);
  if (it != params.cend()) {
garciay's avatar
garciay committed
    loggers::get_instance().log("btp_layer::receive_data: btp_payload=%s", it->second.c_str());
    OCTETSTRING os(str2oct(CHARSTRING(it->second.c_str())));
garciay's avatar
garciay committed
    receive_to_all_layers(os, params);
garciay's avatar
garciay committed
    loggers::get_instance().warning("btp_layer::receive_data: No payload to pass to upper layers");
  }
  // Pass it to the ports if any
  //params.log();
garciay's avatar
garciay committed
  to_all_upper_ports(p, params);
garciay's avatar
garciay committed
btp_layer_factory btp_layer_factory::_f;