+template<typename T1, typename T2>
+bool E2APIndication<T1, T2>::decode(unsigned char *buf, size_t *size)
+{
+
+ asn_dec_rval_t dec_res = asn_decode(0,ATS_ALIGNED_BASIC_PER, &asn_DEF_E2AP_PDU, (void**)&(e2ap_pdu_obj), buf, *size);
+ if(dec_res.code != RC_OK){
+ mdclog_write(MDCLOG_ERR, "Failed to decode: %s","RIC Indication Message");
+ return false;
+ } else {
+ mdclog_write(MDCLOG_INFO, "Successfully decoded: %s","RIC Indication Message");
+ }
+
+ xer_fprint(stdout, &asn_DEF_E2AP_PDU, e2ap_pdu_obj);
+
+ initMsg = e2ap_pdu_obj->choice.initiatingMessage;
+ //write the decoding code.
+ if (initMsg == 0){
+ _error_string = "Invalid reference for E2AP Indication message in get_fields";
+ return false;
+ }
+
+
+ for(int edx = 0; edx < initMsg->value.choice.RICindication.protocolIEs.list.count; edx++) {
+ RICindication_IEs_t *memb_ptr = initMsg->value.choice.RICindication.protocolIEs.list.array[edx];
+ switch(memb_ptr->id)
+ {
+ case (ProtocolIE_ID_id_RICindicationHeader):
+ _indicationIEs->set_ricIndicationHeader(memb_ptr->value.choice.RICindicationHeader.buf, memb_ptr->value.choice.RICindicationHeader.size);
+ break;
+
+ case (ProtocolIE_ID_id_RICindicationMessage):
+ _indicationIEs->set_ricIndicationMessage(memb_ptr->value.choice.RICindicationMessage.buf, memb_ptr->value.choice.RICindicationMessage.size);
+ break;
+
+ case (ProtocolIE_ID_id_RICrequestID):
+ _indicationIEs->set_ricRequestorID(memb_ptr->value.choice.RICrequestID.ricRequestorID);
+ break;
+
+ case (ProtocolIE_ID_id_RANfunctionID):
+ _indicationIEs->set_ranFunctionID(memb_ptr->value.choice.RANfunctionID);
+ break;
+
+ case (ProtocolIE_ID_id_RICindicationSN):
+ _indicationIEs->set_ricIndicationSN(memb_ptr->value.choice.RICindicationSN);
+ break;
+
+ case (ProtocolIE_ID_id_RICindicationType):
+ _indicationIEs->set_ricIndicationType(memb_ptr->value.choice.RICindicationType);
+ break;
+
+ case (ProtocolIE_ID_id_RICactionID):
+ _indicationIEs->set_ricActionID(memb_ptr->value.choice.RICactionID);
+ break;
+
+ case (ProtocolIE_ID_id_RICcallProcessID):
+ _indicationIEs->set_ricCallProcessID(memb_ptr->value.choice.RICcallProcessID.buf,memb_ptr->value.choice.RICcallProcessID.size);
+ break;
+
+ default:
+ break;
+ }
+
+ }
+
+ return true;
+
+}
+
+template<typename T1, typename T2>
+bool E2APIndication<T1,T2>::encode(unsigned char *buf, size_t *size){
+
+ initMsg->procedureCode = ProcedureCode_id_RICindication;
+ initMsg->criticality = Criticality_ignore;
+ initMsg->value.present = InitiatingMessage__value_PR_RICindication;
+
+ bool res;
+ asn_enc_rval_t retval;
+
+ res = setfields(initMsg);
+ if (!res){
+ return false;
+ }
+
+ int ret_constr = asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu_obj, _errbuf, &_errbuf_len);
+ if(ret_constr){
+ _error_string.assign(&_errbuf[0], _errbuf_len);
+ _error_string = "Error encoding E2AP Indication message. Reason = " + _error_string;
+ return false;
+ }
+
+ xer_fprint(stdout, &asn_DEF_E2AP_PDU, e2ap_pdu_obj);
+
+ retval = asn_encode_to_buffer(0, ATS_ALIGNED_BASIC_PER, &asn_DEF_E2AP_PDU, e2ap_pdu_obj, buf, *size);
+ if(retval.encoded == -1){
+ _error_string.assign(strerror(errno));
+ return false;
+ }
+
+ else {
+ if(*size < retval.encoded){
+ std::stringstream ss;
+ ss <<"Error encoding E2AP Indication . Reason = encoded pdu size " << retval.encoded << " exceeds buffer size " << *size << std::endl;
+ _error_string = ss.str();
+ return false;
+ }
+ }
+
+ *size = retval.encoded;
+ return true;
+
+}
+template<typename T1, typename T2>
+bool E2APIndication<T1,T2>::setfields(InitiatingMessage_t *initMsg){
+ unsigned int ie_index;
+
+ if (initMsg == 0){
+ _error_string = "Invalid reference for E2AP Indication message in set_fields";
+ return false;
+ }
+
+
+ RICindication_t * ric_indication = &(initMsg->value.choice.RICindication);
+ ric_indication->protocolIEs.list.count = 0;
+
+ ie_index = 0;
+
+ RICindication_IEs_t *ies_ricreq = &IE_array[ie_index];
+ ies_ricreq->criticality = Criticality_reject;
+ ies_ricreq->id = ProtocolIE_ID_id_RICrequestID;
+ ies_ricreq->value.present = RICindication_IEs__value_PR_RICrequestID;
+ RICrequestID_t *ricrequest_ie = &ies_ricreq->value.choice.RICrequestID;
+ ricrequest_ie->ricRequestorID = _indicationIEs->ricRequestorID;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+
+ ie_index = 1;
+ RICindication_IEs_t *ies_ranfunc = &IE_array[ie_index];
+ ies_ranfunc->criticality = Criticality_reject;
+ ies_ranfunc->id = ProtocolIE_ID_id_RANfunctionID;
+ ies_ranfunc->value.present = RICindication_IEs__value_PR_RANfunctionID;
+ RANfunctionID_t *ranfunction_ie = &ies_ranfunc->value.choice.RANfunctionID;
+ *ranfunction_ie = _indicationIEs->ranFunctionID;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+
+ ie_index = 2;
+ RICindication_IEs_t *ies_actid = &IE_array[ie_index];
+ ies_actid->criticality = Criticality_reject;
+ ies_actid->id = ProtocolIE_ID_id_RICactionID;
+ ies_actid->value.present = RICindication_IEs__value_PR_RICactionID;
+ RICactionID_t *ricaction_ie = &ies_actid->value.choice.RICactionID;
+ *ricaction_ie = _indicationIEs->ricActionID;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+
+ ie_index = 3;
+ RICindication_IEs_t *ies_ricsn = &IE_array[ie_index];
+ ies_ricsn->criticality = Criticality_reject;
+ ies_ricsn->id = ProtocolIE_ID_id_RICindicationSN;
+ ies_ricsn->value.present = RICindication_IEs__value_PR_RICindicationSN;
+ RICindicationSN_t *ricsn_ie = &ies_ricsn->value.choice.RICindicationSN;
+ *ricsn_ie = _indicationIEs->ricIndicationSN;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+
+
+ ie_index = 4;
+ RICindication_IEs_t *ies_indtyp = &IE_array[ie_index];
+ ies_indtyp->criticality = Criticality_reject;
+ ies_indtyp->id = ProtocolIE_ID_id_RICindicationType;
+ ies_indtyp->value.present = RICindication_IEs__value_PR_RICindicationType;
+ RICindicationType_t *rictype_ie = &ies_indtyp->value.choice.RICindicationType;
+ *rictype_ie = _indicationIEs->ricIndicationType;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+
+ ie_index = 5;
+ RICindication_IEs_t *ies_richead = &IE_array[ie_index];
+ ies_richead->criticality = Criticality_reject;
+ ies_richead->id = ProtocolIE_ID_id_RICindicationHeader;
+ ies_richead->value.present = RICindication_IEs__value_PR_RICindicationHeader;
+ RICindicationHeader_t *richeader_ie = &ies_richead->value.choice.RICindicationHeader;
+ richeader_ie->buf = _indicationIEs->ricIndicationHeader;
+ richeader_ie->size = _indicationIEs->ricIndicationHeader_size;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+
+ ie_index = 6;
+ RICindication_IEs_t *ies_indmsg = &IE_array[ie_index];
+ ies_indmsg->criticality = Criticality_reject;
+ ies_indmsg->id = ProtocolIE_ID_id_RICindicationMessage;
+ ies_indmsg->value.present = RICindication_IEs__value_PR_RICindicationMessage;
+ RICindicationMessage_t *ricmsg_ie = &ies_indmsg->value.choice.RICindicationMessage;
+ ricmsg_ie->buf = _indicationIEs->ricIndicationMessage;
+ ricmsg_ie->size = _indicationIEs->ricIndicationMessage_size;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+
+
+ // optional call process id ..
+ if (_indicationIEs->call_process_id_size > 0){
+ ie_index = 7;
+ RICindication_IEs_t *ies_ind_callprocessid = &IE_array[ie_index];
+ ies_ind_callprocessid->criticality = Criticality_reject;
+ ies_ind_callprocessid->id = ProtocolIE_ID_id_RICcallProcessID;
+ ies_ind_callprocessid->value.present = RICindication_IEs__value_PR_RICcallProcessID;
+ RICcallProcessID_t *riccallprocessid_ie = &ies_ind_callprocessid->value.choice.RICcallProcessID;
+ riccallprocessid_ie->buf = _indicationIEs->call_process_id;
+ riccallprocessid_ie->size = _indicationIEs->call_process_id_size;
+ ASN_SEQUENCE_ADD(&(ric_indication->protocolIEs), &(IE_array[ie_index]));
+ }
+
+ return true;
+
+};