+void generate_e2apv1_subscription_response_success(E2AP_PDU *e2ap_pdu, long reqActionIdsAccepted[],
+ long reqActionIdsRejected[], int accept_size, int reject_size,
+ long reqRequestorId, long reqInstanceId) {
+
+ RICsubscriptionResponse_IEs_t *respricreqid =
+ (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+
+ respricreqid->id = ProtocolIE_ID_id_RICrequestID;
+ respricreqid->criticality = 0;
+ respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
+ respricreqid->value.choice.RICrequestID.ricRequestorID = reqRequestorId;
+
+ respricreqid->value.choice.RICrequestID.ricInstanceID = reqInstanceId;
+
+
+ RICsubscriptionResponse_IEs_t *ricactionadmitted =
+ (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+ ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
+ ricactionadmitted->criticality = 0;
+ ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
+
+ RICaction_Admitted_List_t* admlist =
+ (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
+ ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
+
+ // int numAccept = sizeof(reqActionIdsAccepted);
+ int numAccept = accept_size;
+ int numReject = reject_size;
+ // int numReject = sizeof(reqActionIdsRejected);
+
+
+ for (int i=0; i < numAccept ; i++) {
+ fprintf(stderr, "in for loop i = %d\n", i);
+
+ long aid = reqActionIdsAccepted[i];
+
+ RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
+ admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
+ admitie->criticality = 0;
+ admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
+ admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
+
+ ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
+
+ }
+
+ RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
+ ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
+ ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
+
+
+ if (numReject > 0) {
+
+ RICsubscriptionResponse_IEs_t *ricactionrejected =
+ (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+ ricactionrejected->id = ProtocolIE_ID_id_RICactions_NotAdmitted;
+ ricactionrejected->criticality = 0;
+ ricactionrejected->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_NotAdmitted_List;
+
+ RICaction_NotAdmitted_List_t* rejectlist =
+ (RICaction_NotAdmitted_List_t*)calloc(1,sizeof(RICaction_NotAdmitted_List_t));
+ ricactionadmitted->value.choice.RICaction_NotAdmitted_List = *rejectlist;
+
+ for (int i=0; i < numReject; i++) {
+ fprintf(stderr, "in for loop i = %d\n", i);
+
+ long aid = reqActionIdsRejected[i];
+
+ RICaction_NotAdmitted_ItemIEs_t *noadmitie = (RICaction_NotAdmitted_ItemIEs_t*)calloc(1,sizeof(RICaction_NotAdmitted_ItemIEs_t));
+ noadmitie->id = ProtocolIE_ID_id_RICaction_NotAdmitted_Item;
+ noadmitie->criticality = 0;
+ noadmitie->value.present = RICaction_NotAdmitted_ItemIEs__value_PR_RICaction_NotAdmitted_Item;
+ noadmitie->value.choice.RICaction_NotAdmitted_Item.ricActionID = aid;
+
+ ASN_SEQUENCE_ADD(&ricactionrejected->value.choice.RICaction_NotAdmitted_List.list, noadmitie);
+ ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionrejected);
+ }
+ }
+
+
+ SuccessfulOutcome__value_PR pres2;
+ pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
+ SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
+ successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
+ successoutcome->criticality = 0;
+ successoutcome->value.present = pres2;
+ successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
+
+ E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
+
+ e2ap_pdu->present = pres5;
+ e2ap_pdu->choice.successfulOutcome = successoutcome;
+
+ char *error_buf = (char*)calloc(300, sizeof(char));
+ size_t errlen;
+
+ asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
+ printf("error length %d\n", errlen);
+ printf("error buf %s\n", error_buf);
+
+
+}
+
+void generate_e2apv1_subscription_response(E2AP_PDU *e2ap_pdu, E2AP_PDU *sub_req_pdu) {
+
+ //Gather details of the request
+
+ RICsubscriptionRequest_t orig_req =
+ sub_req_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
+
+ RICsubscriptionResponse_IEs_t *ricreqid =
+ (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+
+ int count = orig_req.protocolIEs.list.count;
+ int size = orig_req.protocolIEs.list.size;
+
+ RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
+
+ fprintf(stderr, "count%d\n", count);
+ fprintf(stderr, "size%d\n", size);
+
+ RICsubscriptionRequest_IEs__value_PR pres;
+
+ long responseRequestorId;
+ long responseInstanceId;
+ long responseActionId;
+
+ std::vector<long> actionIds;
+
+ for (int i=0; i < count; i++) {
+ RICsubscriptionRequest_IEs_t *next_ie = ies[i];
+ pres = next_ie->value.present;
+
+ fprintf(stderr, "next present value %d\n", pres);
+
+ switch(pres) {
+ case RICsubscriptionRequest_IEs__value_PR_RICrequestID:
+ {
+ RICrequestID_t reqId = next_ie->value.choice.RICrequestID;
+ long requestorId = reqId.ricRequestorID;
+ long instanceId = reqId.ricInstanceID;
+ fprintf(stderr, "requestorId %d\n", requestorId);
+ fprintf(stderr, "instanceId %d\n", instanceId);
+ responseRequestorId = requestorId;
+ responseInstanceId = instanceId;
+
+ break;
+ }
+ case RICsubscriptionRequest_IEs__value_PR_RANfunctionID:
+ break;
+ case RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails:
+ {
+ RICsubscriptionDetails_t subDetails = next_ie->value.choice.RICsubscriptionDetails;
+ RICeventTriggerDefinition_t triggerDef = subDetails.ricEventTriggerDefinition;
+ RICactions_ToBeSetup_List_t actionList = subDetails.ricAction_ToBeSetup_List;
+
+ int actionCount = actionList.list.count;
+ fprintf(stderr, "action count%d\n", actionCount);
+
+ auto **item_array = actionList.list.array;
+
+ for (int i=0; i < actionCount; i++) {
+ //RICaction_ToBeSetup_Item_t
+ auto *next_item = item_array[i];
+ RICactionID_t actionId = ((RICaction_ToBeSetup_ItemIEs*)next_item)->value.choice.RICaction_ToBeSetup_Item.ricActionID;
+ fprintf(stderr, "Next Action ID %ld\n", actionId);
+ responseActionId = actionId;
+ actionIds.push_back(responseActionId);
+ }
+
+ break;
+ }
+ }
+
+ }
+
+ fprintf(stderr, "After Processing Subscription Request\n");
+
+ fprintf(stderr, "requestorId %d\n", responseRequestorId);
+ fprintf(stderr, "instanceId %d\n", responseInstanceId);
+
+
+ for (int i=0; i < actionIds.size(); i++) {
+ fprintf(stderr, "Action ID %d %ld\n", i, actionIds.at(i));
+
+ }
+
+
+ RICsubscriptionResponse_IEs_t *respricreqid =
+ (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+
+ respricreqid->id = ProtocolIE_ID_id_RICrequestID;
+ respricreqid->criticality = 0;
+ respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
+ respricreqid->value.choice.RICrequestID.ricRequestorID = responseRequestorId;
+
+ respricreqid->value.choice.RICrequestID.ricInstanceID = responseInstanceId;
+
+
+ RICsubscriptionResponse_IEs_t *ricactionadmitted =
+ (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+ ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
+ ricactionadmitted->criticality = 0;
+ ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
+
+ RICaction_Admitted_List_t* admlist =
+ (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
+ ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
+
+ for (int i=0; i < actionIds.size(); i++) {
+ fprintf(stderr, "in for loop i = %d\n", i);
+
+ long aid = actionIds.at(i);
+
+ RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
+ admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
+ admitie->criticality = 0;
+ admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
+ admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
+
+ ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
+
+ }
+
+
+ RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
+
+ ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
+ ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
+
+
+ SuccessfulOutcome__value_PR pres2;
+ pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
+ SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
+ successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
+ successoutcome->criticality = 0;
+ successoutcome->value.present = pres2;
+ successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
+
+ E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
+
+ e2ap_pdu->present = pres5;
+ e2ap_pdu->choice.successfulOutcome = successoutcome;
+
+ char *error_buf = (char*)calloc(300, sizeof(char));
+ size_t errlen;
+
+ asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
+ printf("error length %d\n", errlen);
+ printf("error buf %s\n", error_buf);
+
+}
+
+void generate_e2apv1_indication_request_parameterized(E2AP_PDU *e2ap_pdu,
+ long requestorId,
+ long instanceId,
+ long ranFunctionId,
+ long actionId,
+ long seqNum,
+ uint8_t *ind_header_buf,
+ int header_length,
+ uint8_t *ind_message_buf,
+ int message_length) {
+
+ fprintf(stderr, "ind1\n");
+ RICindication_IEs_t *ricind_ies = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+ RICindication_IEs_t *ricind_ies2 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+ RICindication_IEs_t *ricind_ies3 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+ RICindication_IEs_t *ricind_ies4 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+ RICindication_IEs_t *ricind_ies5 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+ RICindication_IEs_t *ricind_ies6 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+ RICindication_IEs_t *ricind_ies7 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+ RICindication_IEs_t *ricind_ies8 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+
+ RICindication_IEs__value_PR pres3;
+
+ pres3 = RICindication_IEs__value_PR_RICrequestID;
+ ricind_ies->id = ProtocolIE_ID_id_RICrequestID;
+ ricind_ies->criticality = 0;
+ ricind_ies->value.present = pres3;
+ ricind_ies->value.choice.RICrequestID.ricRequestorID = requestorId;
+ ricind_ies->value.choice.RICrequestID.ricInstanceID = instanceId;
+
+ fprintf(stderr, "ind2\n");
+
+ pres3 = RICindication_IEs__value_PR_RANfunctionID;
+ ricind_ies2->id = ProtocolIE_ID_id_RANfunctionID;
+ ricind_ies2->criticality = 0;
+ ricind_ies2->value.present = pres3;
+ ricind_ies2->value.choice.RANfunctionID = ranFunctionId;
+
+
+ ricind_ies3->id = ProtocolIE_ID_id_RICactionID;
+ ricind_ies3->criticality = 0;
+ pres3 = RICindication_IEs__value_PR_RICactionID;
+ ricind_ies3->value.present = pres3;
+ ricind_ies3->value.choice.RICactionID = actionId;
+
+
+ pres3 = RICindication_IEs__value_PR_RICindicationSN;
+ ricind_ies4->id = ProtocolIE_ID_id_RICindicationSN;
+ ricind_ies4->criticality = 0;
+ ricind_ies4->value.present = pres3;
+ ricind_ies4->value.choice.RICindicationSN = seqNum;
+
+ //Indication type is REPORT
+ pres3 = RICindication_IEs__value_PR_RICindicationType;
+ ricind_ies5->id = ProtocolIE_ID_id_RICindicationType;
+ ricind_ies5->criticality = 0;
+ ricind_ies5->value.present = pres3;
+ ricind_ies5->value.choice.RICindicationType = 0;
+
+
+ uint8_t *buf2 = (uint8_t *)"reportheader";
+ OCTET_STRING_t *hdr_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
+
+ hdr_str->buf = (uint8_t*)calloc(1,header_length);
+ hdr_str->size = header_length;
+ memcpy(hdr_str->buf, ind_header_buf, header_length);
+
+ fprintf(stderr, "ind3\n");
+
+ ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,header_length);
+
+ pres3 = RICindication_IEs__value_PR_RICindicationHeader;
+ ricind_ies6->id = ProtocolIE_ID_id_RICindicationHeader;
+ ricind_ies6->criticality = 0;
+ ricind_ies6->value.present = pres3;
+ ricind_ies6->value.choice.RICindicationHeader.size = header_length;
+ memcpy(ricind_ies6->value.choice.RICindicationHeader.buf, ind_header_buf, header_length);
+
+ ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
+
+
+
+
+ pres3 = RICindication_IEs__value_PR_RICindicationMessage;
+ ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
+ fprintf(stderr, "after encoding message 1\n");
+
+ ricind_ies7->criticality = 0;
+ ricind_ies7->value.present = pres3;
+
+ fprintf(stderr, "after encoding message 2\n");
+
+ fprintf(stderr, "after encoding message 3\n");
+ ricind_ies7->value.choice.RICindicationMessage.size = message_length;
+
+ fprintf(stderr, "after encoding message 4\n");
+ memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, ind_message_buf, message_length);
+
+ fprintf(stderr, "after encoding message 5\n");
+
+ uint8_t *cpid_buf = (uint8_t *)"cpid";
+ OCTET_STRING_t cpid_str;
+
+ printf("5.1\n");
+
+ int cpid_buf_len = strlen((char*)cpid_buf);
+ pres3 = RICindication_IEs__value_PR_RICcallProcessID;
+ ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
+
+ ricind_ies8->criticality = 0;
+ ricind_ies8->value.present = pres3;
+
+ ricind_ies8->value.choice.RICcallProcessID.buf = (uint8_t*)calloc(1,cpid_buf_len);
+ ricind_ies8->value.choice.RICcallProcessID.size = cpid_buf_len;
+
+ memcpy(ricind_ies8->value.choice.RICcallProcessID.buf, cpid_buf, cpid_buf_len);
+
+ printf("5.2\n");
+
+ RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
+
+
+ int ret;
+
+ ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
+
+ ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
+
+ printf("5.3\n");