BTPLayer.cc 4.01 KB
Newer Older
#include "BTPLayer.hh"
#include "BTPTypes.hh"
filatov's avatar
filatov committed

garciay's avatar
garciay committed
#include "loggers.hh"

BTPLayer::BTPLayer(const std::string & p_type, const std::string & param) : TLayer<LibItsBtp__TestSystem::BtpPort>(p_type), _params(), _codec() {
  loggers::get_instance().log(">>> BTPLayer::BTPLayer: %s, %s", to_string().c_str(), param.c_str());
  // Setup parameters
  Params::convert(_params, param);
  
  // Sanity check
  Params::const_iterator it = _params.find(Params::btp_type);
  if (it == _params.cend()) {
    _params[Params::btp_type] = std::string("btpA");
  }
  it = _params.find(Params::btp_destination_port);
  if (it == _params.cend()) {
    _params[Params::btp_destination_port] = std::to_string(2001);
  }
  it = _params.find(Params::btp_info);
  if (it == _params.cend()) {
    _params[Params::btp_info] = std::to_string(0);
  }
garciay's avatar
garciay committed
}

garciay's avatar
garciay committed
void BTPLayer::sendMsg(const LibItsBtp__TestSystem::BtpReq& p, Params& params){
garciay's avatar
garciay committed
  loggers::get_instance().log(">>> BTPLayer::sendMsg");
  //params.log();
garciay's avatar
garciay committed

  // Encode BTP PDU
filatov's avatar
filatov committed
  OCTETSTRING data;
garciay's avatar
garciay committed
  _codec.encode(p.msgOut(), data);
garciay's avatar
garciay committed
  sendData(data, params);
garciay's avatar
garciay committed
void BTPLayer::sendData(OCTETSTRING& data, Params& params) {
  loggers::get_instance().log_msg(">>> BTPLayer::sendData: ", data);
  params.log();

  Params::const_iterator it = params.find(Params::packetize);
  if (it != params.cend()) {
    LibItsBtp__TypesAndValues::BtpHeader header;
    if (_params[Params::btp_type].compare("btpA") == 0) {
      header.btpAHeader() = LibItsBtp__TypesAndValues::BtpAHeader(
                                                                  std::stoi(_params[Params::btp_destination_port]),
                                                                  std::stoi(_params[Params::btp_info])
                                                                  );
    } else {
      header.btpBHeader() = LibItsBtp__TypesAndValues::BtpBHeader(
                                                                  std::stoi(_params[Params::btp_destination_port]),
                                                                  std::stoi(_params[Params::btp_info])
                                                                  );
    }
    LibItsBtp__TypesAndValues::BtpPacket p(
                                           header,
                                           data
                                           );
    loggers::get_instance().log_msg("BTPLayer::sendData: ", p);
    // Encode BTP PDU
    OCTETSTRING os;
    _codec.encode(p, os);
    data = os;
  }
filatov's avatar
filatov committed
  sendToAllLayers(data, params);
}
garciay's avatar
garciay committed
void BTPLayer::receiveData(OCTETSTRING& data, Params& params)
filatov's avatar
filatov committed
{
garciay's avatar
garciay committed
  loggers::get_instance().log_msg(">>> BTPLayer::receiveData: ", data);
  params.log();  
garciay's avatar
garciay committed
  // Decode the payload
  LibItsBtp__TestSystem::BtpInd p;
  Params::const_iterator it = params.find(Params::gn_next_header);
  if (it != params.cend()) {
    _codec.set_btp_type((it->second.compare("02") == 0) ? BTPCodec::btpB : BTPCodec::btpA);
  }
  _codec.decode(data, p.msgIn(), &params);
garciay's avatar
garciay committed
  
  // Pass the BTP raw payload to the upper layers if any
  it = params.find(Params::btp_payload);
  if (it != params.cend()) {
    loggers::get_instance().log("BTPLayer::receiveData: btp_payload=%s", it->second.c_str());
    OCTETSTRING os(str2oct(CHARSTRING(it->second.c_str())));
    receiveToAllLayers(os, params);
  } else {
    loggers::get_instance().warning("BTPLayer::receiveData: No payload to pass to upper layers");
  }
  // Pass it to the ports if amy
  //params.log();
garciay's avatar
garciay committed
  toAllUpperPorts(p, params);
filatov's avatar
filatov committed
}

class BTPFactory : public LayerFactory {
  static BTPFactory _f;
public:
  BTPFactory();
  virtual Layer * createLayer(const std::string &  type, const std::string &  param);
};

BTPFactory::BTPFactory(){
garciay's avatar
garciay committed
  // Register factory
  loggers::get_instance().log(">>> BTPFactory::BTPFactory");
  LayerStackBuilder::RegisterLayerFactory("BTP", this);
garciay's avatar
garciay committed
Layer * BTPFactory::createLayer(const std::string & p_type, const std::string & param){
garciay's avatar
garciay committed
  return new BTPLayer(p_type, param);
filatov's avatar
filatov committed
}

BTPFactory BTPFactory::_f;