uppertester_ivim_codec.cc 9.31 KB
Newer Older
#include <string>
#include <memory>
garciay's avatar
garciay committed
#include "uppertester_ivim_codec.hh"
#include "loggers.hh"

garciay's avatar
garciay committed
#include "uppertester_types.hh"
garciay's avatar
garciay committed
#include "ivim_codec.hh"

template <typename T_type> class OPTIONAL;
class TTCN_EncDec;

garciay's avatar
garciay committed
int uppertester_ivim_codec::encode (const Record_Type& msg, OCTETSTRING& data)
garciay's avatar
garciay committed
  loggers::get_instance().log_msg(">>> uppertester_ivim_codec::encode: ", (const Record_Type&)msg);
  
  TTCN_EncDec::clear_error();
  TTCN_Buffer encoding_buffer;
  if (std::string(msg.get_descriptor()->name).compare("@LibItsIvim_TypesAndValues.UtIvimInitialize") == 0) {
garciay's avatar
garciay committed
    encoding_buffer.put_c(static_cast<const unsigned char>(uppertester_ivim_codec::c_utIvimInitialize));
  } else if (std::string(msg.get_descriptor()->name).compare("@LibItsIvim_TypesAndValues.UtIvimTrigger") == 0) {
garciay's avatar
garciay committed
    encoding_buffer.put_c(static_cast<const unsigned char>(uppertester_ivim_codec::c_utIvimTrigger));
    // See ETSI TR 103 099 V1.4.1 Clause C.9.1 GenerateIvimEvent
    unsigned char flags = 0x00;
    const LibItsIvim__TypesAndValues::UtIvimTrigger &r = static_cast<const LibItsIvim__TypesAndValues::UtIvimTrigger &>(msg);
    if (r.validFrom().is_present()) { // V
      flags |= 0x80;
    }
    if (r.validTo().is_present()) { // R
      flags |= 0x40;
    }
    if (r.repetitionInterval().is_present()) { // T
      flags |= 0x20;
    }
    encoding_buffer.put_c(flags);
garciay's avatar
garciay committed
    loggers::get_instance().log_to_hexa("uppertester_ivim_codec::encode: flags=", encoding_buffer);
    // Continue with encoding
  } else if (std::string(msg.get_descriptor()->name).compare("@LibItsIvim_TypesAndValues.UtIvimUpdate") == 0) {
garciay's avatar
garciay committed
    encoding_buffer.put_c(static_cast<const unsigned char>(uppertester_ivim_codec::c_utIvimUpdate));
    // See ETSI TR 103 099 V1.4.1 Clause C.9.2	UpdateIvimEvent
    unsigned char flags = 0x00;
    const LibItsIvim__TypesAndValues::UtIvimUpdate &r = static_cast<const LibItsIvim__TypesAndValues::UtIvimUpdate &>(msg);
    if (r.timeStamp().is_present()) { // T
      flags |= 0x80;
    }
    if (r.validFrom().is_present()) { // V
      flags |= 0x40;
    }
    if (r.validTo().is_present()) { // R
      flags |= 0x20;
    }
    encoding_buffer.put_c(flags);
garciay's avatar
garciay committed
    loggers::get_instance().log_to_hexa("uppertester_ivim_codec::encode: flags=", encoding_buffer);
    // Continue with encoding
  } else if (std::string(msg.get_descriptor()->name).compare("@LibItsIvim_TypesAndValues.UtIvimTermination") == 0) {
    // See ETSI TR 103 099 V1.4.1 Clause C.9.3	TerminateIvimEvent
garciay's avatar
garciay committed
    encoding_buffer.put_c(static_cast<const unsigned char>(uppertester_ivim_codec::c_utIvimTermination));
  } else { // Error
YannGarcia's avatar
YannGarcia committed
    data = OCTETSTRING(0, nullptr);
garciay's avatar
garciay committed
    loggers::get_instance().log("<<< uppertester_ivim_codec::encode: Return -1");
    return -1;
  }
  encode_(msg, *msg.get_descriptor(), encoding_buffer);
  data = OCTETSTRING(encoding_buffer.get_len(), encoding_buffer.get_data());
garciay's avatar
garciay committed
  loggers::get_instance().log_msg("<<< uppertester_ivim_codec::encode: data=", data);
garciay's avatar
garciay committed
int uppertester_ivim_codec::encode_ (const Base_Type& type, const TTCN_Typedescriptor_t& field_descriptor, TTCN_Buffer& encoding_buffer)
garciay's avatar
garciay committed
  loggers::get_instance().log(">>> uppertester_ivim_codec::encode_: processing %s/%s/%p", type.get_descriptor()->name, field_descriptor.name, dynamic_cast<const Record_Type*>(&type));
  loggers::get_instance().log_msg(">>> uppertester_ivim_codec::encode_: ", type);
  
  if (dynamic_cast<const Record_Type*>(&type) != NULL) {
    const Record_Type& r = (const Record_Type &)type;
garciay's avatar
garciay committed
    loggers::get_instance().log("uppertester_ivim_codec::encode_: processing Record_Type %s", r.get_descriptor()->name);
    for(int i = 0; i < r.get_count(); i++) {
garciay's avatar
garciay committed
      loggers::get_instance().log("uppertester_ivim_codec::encode_: processing %s/%s/%s - %d (1 ==> use dynamic_cast<const OPTIONAL<...>) - %d", r.fld_name(i), r.fld_descr(i)->name, r.get_at(i)->get_descriptor()->name, r.get_at(i)->is_optional(), r.get_at(i)->is_present());
      if (r.get_at(i)->is_present()) {
        if (encode_(*r.get_at(i), *r.fld_descr(i), encoding_buffer) == -1) {
garciay's avatar
garciay committed
          loggers::get_instance().warning("uppertester_ivim_codec::encode_: -1 result code returned");
          return -1;
        }
      } else {
        std::string s(r.fld_descr(i)->name);
        if (
            (s.rfind(".timeStamp") != string::npos) ||
            (s.rfind(".validFrom") != string::npos) ||
            (s.rfind(".validTo") != string::npos) ||
            (s.rfind(".repetitionInterval") != string::npos)
            ) { // Pad with six bytes
garciay's avatar
garciay committed
          loggers::get_instance().log("uppertester_ivim_codec::encode_: Padding for %s", field_descriptor.name);
          encoding_buffer.put_c((unsigned char)0x00);
          encoding_buffer.put_c((unsigned char)0x00);
          encoding_buffer.put_c((unsigned char)0x00);
          encoding_buffer.put_c((unsigned char)0x00);
          encoding_buffer.put_c((unsigned char)0x00);
          encoding_buffer.put_c((unsigned char)0x00);
        }
      }
    } // End of 'for' statement
  } else {
    std::string s(field_descriptor.name);
garciay's avatar
garciay committed
    loggers::get_instance().log("uppertester_ivim_codec::encode_: field to process %s", s.c_str());
    if (s.rfind(".iviIdentificationNumber") != string::npos) {
      const INTEGER& i = static_cast<const INTEGER&>(type);
garciay's avatar
garciay committed
      loggers::get_instance().log_msg("uppertester_ivim_codec::encode_: i=", i);
      encoding_buffer.put_string(int2oct(i, 2));
    } else if (
               (s.rfind(".timeStamp") != string::npos) ||
               (s.rfind(".validTo") != string::npos) ||
               (s.rfind(".validFrom") != string::npos) ||
               (s.rfind(".repetitionInterval") != string::npos)
              ) {
      const INTEGER& i = static_cast<const INTEGER&>(type);
garciay's avatar
garciay committed
      loggers::get_instance().log_msg("uppertester_ivim_codec::encode_: i=", i);
      loggers::get_instance().log_msg("uppertester_ivim_codec::encode_: int2oct=", int2oct(i, 6));
      encoding_buffer.put_string(int2oct(i, 6));
    } else {
garciay's avatar
garciay committed
      loggers::get_instance().log("uppertester_ivim_codec::encode_ (else): processing type %s/%s", type.get_descriptor()->name, field_descriptor.name);
      type.encode(field_descriptor, encoding_buffer, TTCN_EncDec::CT_RAW);
garciay's avatar
garciay committed
  loggers::get_instance().log_to_hexa("<<< uppertester_ivim_codec::encode_: encoding_buffer=", encoding_buffer);
garciay's avatar
garciay committed
int uppertester_ivim_codec::decode (const OCTETSTRING& data, Record_Type& msg, params* params)
{
  TTCN_EncDec::clear_error();
  TTCN_Buffer decoding_buffer(data);
  _params = params;
  
garciay's avatar
garciay committed
  loggers::get_instance().log_to_hexa(">>> uppertester_ivim_codec::decode: decoding_buffer=", decoding_buffer);
  //decode_(msg, *msg.get_descriptor(), decoding_buffer);
  
garciay's avatar
garciay committed
  loggers::get_instance().log_msg("<<< uppertester_ivim_codec::decode: ", (const Record_Type&)msg);
garciay's avatar
garciay committed
std::unique_ptr<Base_Type> uppertester_ivim_codec::decode (const OCTETSTRING& data, params* params) {

  std::unique_ptr<Base_Type> result;
  
  const unsigned char* ptr = static_cast<const unsigned char*>(data);
garciay's avatar
garciay committed
  if (*ptr != uppertester_ivim_codec::c_utIvimEventInd) {
    LibItsIvim__TypesAndValues::UtIvimResults res;
    decode(data, res, params);
    result.reset((Base_Type *)res.clone());
  } else {
    LibItsIvim__TypesAndValues::UtIvimEventInd ind;
    decode(data, ind, params);
    result.reset((Base_Type *)ind.clone());
  }

  return result;
}

garciay's avatar
garciay committed
int uppertester_ivim_codec::decode (const OCTETSTRING& data, LibItsIvim__TypesAndValues::UtIvimResults& msg, params* params)
garciay's avatar
garciay committed
  loggers::get_instance().log_to_hexa(">>> uppertester_ivim_codec::decode: decoding_buffer=", data);
  
  const unsigned char* ptr = static_cast<const unsigned char*>(data);
garciay's avatar
garciay committed
  if (*ptr == uppertester_ivim_codec::c_utIvimInitializeResult) {
    msg.utIvimInitializeResult() = BOOLEAN(*(ptr + 1) == 0x01);
garciay's avatar
garciay committed
  } else if (*ptr == uppertester_ivim_codec::c_utIvimTerminationResult) { 
    msg.utIvimTerminationResult() = BOOLEAN(*(ptr + 1) == 0x01);
garciay's avatar
garciay committed
  } else if (*ptr == uppertester_ivim_codec::c_utIvimTriggerResult) {
    LibItsIvim__TypesAndValues::UtIvimTriggerResult r;
    ptr += 1;
    r.result() = BOOLEAN(*ptr == 0x01);
    ptr += 1;
    OCTETSTRING os(2, ptr);
    ptr += 2;
    r.iviIdentificationNumber() = oct2int(os);
    msg.utIvimTriggerResult() = r;
garciay's avatar
garciay committed
  } else if (*ptr == uppertester_ivim_codec::c_utIvimUpdateResult) {
    LibItsIvim__TypesAndValues::UtIvimUpdateResult r;
    ptr += 1;
    r.result() = BOOLEAN(*ptr == 0x01);
    ptr += 1;
    OCTETSTRING os(2, ptr);
    ptr += 2;
    r.iviIdentificationNumber() = oct2int(os);
    msg.utIvimUpdateResult() = r;
  } else {
garciay's avatar
garciay committed
    TTCN_warning("uppertester_ivim_codec::decode: Unsupported result");
garciay's avatar
garciay committed
  loggers::get_instance().log_msg("<<< uppertester_ivim_codec::decode", msg);
garciay's avatar
garciay committed
int uppertester_ivim_codec::decode (const OCTETSTRING& data, LibItsIvim__TypesAndValues::UtIvimEventInd& msg, params* params)
garciay's avatar
garciay committed
  loggers::get_instance().log_to_hexa(">>> uppertester_ivim_codec::decode: decoding_buffer=", data);
  const unsigned char* ptr = static_cast<const unsigned char*>(data) + 1;
  OCTETSTRING os(2, ptr);
  ptr += 2;
  unsigned int length = oct2int(os);
garciay's avatar
garciay committed
  loggers::get_instance().log("uppertester_ivim_codec::decode: IVIM message length=%d", length);
  os = OCTETSTRING(length, ptr);
garciay's avatar
garciay committed
  loggers::get_instance().log_to_hexa("uppertester_ivim_codec::decode: IVIM message=", os);
  ivim_codec codec;
  codec.decode(os, msg.iviMsg(), params);
garciay's avatar
garciay committed
  loggers::get_instance().log_msg("<<< uppertester_ivim_codec::decode", msg);