Newer
Older
ivim_layer::ivim_layer(const std::string & p_type, const std::string & param) : t_layer<LibItsIvim__TestSystem::IvimPort>(p_type), _params(), _codec() {
loggers::get_instance().log(">>> ivim_layer::ivim_layer: %s, %s", to_string().c_str(), param.c_str());
_params.insert(std::make_pair<std::string, std::string>("its_aid", "139")); // ETSI TS 102 965 V1.2.1 (2015-06)
_params.insert(std::make_pair<std::string, std::string>("payload_type", "6")); // IVI message id - See ETSI TS 103 301
// Register this object for AdapterControlPort
loggers::get_instance().log("ivim_layer::ivim_layer: Register %s/%p", p_type.c_str(), this);
registration<ivim_layer>::get_instance().add_item(p_type, this);
void ivim_layer::sendMsg(const LibItsIvim__TestSystem::IvimReq& p, params& params){
loggers::get_instance().log_msg(">>> ivim_layer::sendMsg: ", p);
// Encode IVIM PDU
OCTETSTRING data;
if (_codec.encode(p.msgOut(), data) == -1) {
loggers::get_instance().warning("ivim_layer::sendMsg: Encoding failure");
void ivim_layer::sendMsg(const LibItsIvim__TestSystem::IvimInd& p, params& params){
loggers::get_instance().log_msg(">>> ivim_layer::sendMsg: ", p);
// Encode IVIM PDU
OCTETSTRING data;
if (_codec.encode(p.msgIn(), data) == -1) {
loggers::get_instance().warning("ivim_layer::sendMsg: Encoding failure");
return;
}
send_data(data, _params);
}
void ivim_layer::send_data(OCTETSTRING& data, params& params) {
loggers::get_instance().log_msg(">>> ivim_layer::send_data: ", data);
void ivim_layer::receive_data(OCTETSTRING& data, params& params)
loggers::get_instance().log_msg(">>> ivim_layer::receive_data: ", data);
// Sanity check
if (*(static_cast<const unsigned char*>(data)+ 1) != 0x06) { // Check that received packet has IVI message id - See ETSI TS 102 894
// Not a IVIM message, discard it
loggers::get_instance().warning("ivim_layer::receive_data: Wrong message id: 0x%02x", *(static_cast<const unsigned char*>(data)+ 1));
// Decode the payload
LibItsIvim__TestSystem::IvimInd p;
_codec.decode(data, p.msgIn());
if (!p.msgIn().is_bound()) {
// Discard it
return;
} // else, continue
// Process lower layer data
// gnNextHeader
params::const_iterator it = params.find(params::gn_next_header);
if (it != params.cend()) {
p.gnNextHeader() = std::stoi(it->second);
} else {
p.gnNextHeader().set_to_omit();
}
// gnHeaderType
if (it != params.cend()) {
p.gnHeaderType() = std::stoi(it->second);
} else {
p.gnHeaderType().set_to_omit();
}
// gnHeaderSubtype
if (it != params.cend()) {
p.gnHeaderSubtype() = std::stoi(it->second);
} else {
p.gnHeaderSubtype().set_to_omit();
}
// gnLifetime
if (it != params.cend()) {
p.gnLifetime() = std::stoi(it->second);
} else {
p.gnLifetime().set_to_omit();
}
// gnTrafficClass
if (it != params.cend()) {
p.gnTrafficClass() = std::stoi(it->second);
} else {
p.gnTrafficClass().set_to_omit();
}
// btpDestinationPort
if (it != params.cend()) {
p.btpDestinationPort() = std::stoi(it->second);
} else {
p.btpDestinationPort().set_to_omit();
}
// btpInfo
if (it != params.cend()) {
p.btpInfo() = std::stoi(it->second);
} else {
p.btpInfo().set_to_omit();
}
// ssp
loggers::get_instance().log("ivim_layer::receive_data: ssp=%s", it->second.c_str());
} else {
p.ssp().set_to_omit();
}
// its_aid
it = params.find(params::its_aid);
if (it != params.cend()) {
p.its__aid() = std::stoi(it->second);
} else {
p.its__aid().set_to_omit();
}
int ivim_layer::enable_secured_mode(const std::string& p_certificate_id, const boolean p_enforce_security) {
loggers::get_instance().log(">>> ivim_layer::enable_secured_mode: '%s' - %x", p_certificate_id.c_str(), p_enforce_security);
return 0;
}
int ivim_layer::disable_secured_mode() {
loggers::get_instance().log(">>> ivim_layer::disable_secured_mode");
return 0;
}