open5gs/lib/sbi/openapi/model/policy_association.c

347 lines
12 KiB
C

#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "policy_association.h"
OpenAPI_policy_association_t *OpenAPI_policy_association_create(
OpenAPI_policy_association_request_t *request,
OpenAPI_list_t *triggers,
OpenAPI_service_area_restriction_t *serv_area_res,
OpenAPI_wireline_service_area_restriction_t *wl_serv_area_res,
bool is_rfsp,
int rfsp,
OpenAPI_smf_selection_data_t *smf_sel_info,
OpenAPI_ambr_t *ue_ambr,
OpenAPI_list_t* pras,
char *supp_feat
)
{
OpenAPI_policy_association_t *policy_association_local_var = ogs_malloc(sizeof(OpenAPI_policy_association_t));
ogs_assert(policy_association_local_var);
policy_association_local_var->request = request;
policy_association_local_var->triggers = triggers;
policy_association_local_var->serv_area_res = serv_area_res;
policy_association_local_var->wl_serv_area_res = wl_serv_area_res;
policy_association_local_var->is_rfsp = is_rfsp;
policy_association_local_var->rfsp = rfsp;
policy_association_local_var->smf_sel_info = smf_sel_info;
policy_association_local_var->ue_ambr = ue_ambr;
policy_association_local_var->pras = pras;
policy_association_local_var->supp_feat = supp_feat;
return policy_association_local_var;
}
void OpenAPI_policy_association_free(OpenAPI_policy_association_t *policy_association)
{
if (NULL == policy_association) {
return;
}
OpenAPI_lnode_t *node;
OpenAPI_policy_association_request_free(policy_association->request);
OpenAPI_list_free(policy_association->triggers);
OpenAPI_service_area_restriction_free(policy_association->serv_area_res);
OpenAPI_wireline_service_area_restriction_free(policy_association->wl_serv_area_res);
OpenAPI_smf_selection_data_free(policy_association->smf_sel_info);
OpenAPI_ambr_free(policy_association->ue_ambr);
OpenAPI_list_for_each(policy_association->pras, node) {
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data;
ogs_free(localKeyValue->key);
OpenAPI_presence_info_free(localKeyValue->value);
ogs_free(localKeyValue);
}
OpenAPI_list_free(policy_association->pras);
ogs_free(policy_association->supp_feat);
ogs_free(policy_association);
}
cJSON *OpenAPI_policy_association_convertToJSON(OpenAPI_policy_association_t *policy_association)
{
cJSON *item = NULL;
if (policy_association == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [PolicyAssociation]");
return NULL;
}
item = cJSON_CreateObject();
if (policy_association->request) {
cJSON *request_local_JSON = OpenAPI_policy_association_request_convertToJSON(policy_association->request);
if (request_local_JSON == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [request]");
goto end;
}
cJSON_AddItemToObject(item, "request", request_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [request]");
goto end;
}
}
if (policy_association->triggers) {
cJSON *triggers = cJSON_AddArrayToObject(item, "triggers");
if (triggers == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [triggers]");
goto end;
}
OpenAPI_lnode_t *triggers_node;
OpenAPI_list_for_each(policy_association->triggers, triggers_node) {
if (cJSON_AddStringToObject(triggers, "", OpenAPI_request_trigger_ToString((intptr_t)triggers_node->data)) == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [triggers]");
goto end;
}
}
}
if (policy_association->serv_area_res) {
cJSON *serv_area_res_local_JSON = OpenAPI_service_area_restriction_convertToJSON(policy_association->serv_area_res);
if (serv_area_res_local_JSON == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [serv_area_res]");
goto end;
}
cJSON_AddItemToObject(item, "servAreaRes", serv_area_res_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [serv_area_res]");
goto end;
}
}
if (policy_association->wl_serv_area_res) {
cJSON *wl_serv_area_res_local_JSON = OpenAPI_wireline_service_area_restriction_convertToJSON(policy_association->wl_serv_area_res);
if (wl_serv_area_res_local_JSON == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [wl_serv_area_res]");
goto end;
}
cJSON_AddItemToObject(item, "wlServAreaRes", wl_serv_area_res_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [wl_serv_area_res]");
goto end;
}
}
if (policy_association->is_rfsp) {
if (cJSON_AddNumberToObject(item, "rfsp", policy_association->rfsp) == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [rfsp]");
goto end;
}
}
if (policy_association->smf_sel_info) {
cJSON *smf_sel_info_local_JSON = OpenAPI_smf_selection_data_convertToJSON(policy_association->smf_sel_info);
if (smf_sel_info_local_JSON == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [smf_sel_info]");
goto end;
}
cJSON_AddItemToObject(item, "smfSelInfo", smf_sel_info_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [smf_sel_info]");
goto end;
}
}
if (policy_association->ue_ambr) {
cJSON *ue_ambr_local_JSON = OpenAPI_ambr_convertToJSON(policy_association->ue_ambr);
if (ue_ambr_local_JSON == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [ue_ambr]");
goto end;
}
cJSON_AddItemToObject(item, "ueAmbr", ue_ambr_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [ue_ambr]");
goto end;
}
}
if (policy_association->pras) {
cJSON *pras = cJSON_AddObjectToObject(item, "pras");
if (pras == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [pras]");
goto end;
}
cJSON *localMapObject = pras;
OpenAPI_lnode_t *pras_node;
if (policy_association->pras) {
OpenAPI_list_for_each(policy_association->pras, pras_node) {
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)pras_node->data;
cJSON *itemLocal = localKeyValue->value ?
OpenAPI_presence_info_convertToJSON(localKeyValue->value) :
cJSON_CreateNull();
if (itemLocal == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [inner]");
goto end;
}
cJSON_AddItemToObject(localMapObject, localKeyValue->key, itemLocal);
}
}
}
if (cJSON_AddStringToObject(item, "suppFeat", policy_association->supp_feat) == NULL) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed [supp_feat]");
goto end;
}
end:
return item;
}
OpenAPI_policy_association_t *OpenAPI_policy_association_parseFromJSON(cJSON *policy_associationJSON)
{
OpenAPI_policy_association_t *policy_association_local_var = NULL;
cJSON *request = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "request");
OpenAPI_policy_association_request_t *request_local_nonprim = NULL;
if (request) {
request_local_nonprim = OpenAPI_policy_association_request_parseFromJSON(request);
}
cJSON *triggers = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "triggers");
OpenAPI_list_t *triggersList;
if (triggers) {
cJSON *triggers_local_nonprimitive;
if (!cJSON_IsArray(triggers)) {
ogs_error("OpenAPI_policy_association_parseFromJSON() failed [triggers]");
goto end;
}
triggersList = OpenAPI_list_create();
cJSON_ArrayForEach(triggers_local_nonprimitive, triggers ) {
if (!cJSON_IsString(triggers_local_nonprimitive)){
ogs_error("OpenAPI_policy_association_parseFromJSON() failed [triggers]");
goto end;
}
OpenAPI_list_add(triggersList, (void *)OpenAPI_request_trigger_FromString(triggers_local_nonprimitive->valuestring));
}
}
cJSON *serv_area_res = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "servAreaRes");
OpenAPI_service_area_restriction_t *serv_area_res_local_nonprim = NULL;
if (serv_area_res) {
serv_area_res_local_nonprim = OpenAPI_service_area_restriction_parseFromJSON(serv_area_res);
}
cJSON *wl_serv_area_res = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "wlServAreaRes");
OpenAPI_wireline_service_area_restriction_t *wl_serv_area_res_local_nonprim = NULL;
if (wl_serv_area_res) {
wl_serv_area_res_local_nonprim = OpenAPI_wireline_service_area_restriction_parseFromJSON(wl_serv_area_res);
}
cJSON *rfsp = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "rfsp");
if (rfsp) {
if (!cJSON_IsNumber(rfsp)) {
ogs_error("OpenAPI_policy_association_parseFromJSON() failed [rfsp]");
goto end;
}
}
cJSON *smf_sel_info = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "smfSelInfo");
OpenAPI_smf_selection_data_t *smf_sel_info_local_nonprim = NULL;
if (smf_sel_info) {
smf_sel_info_local_nonprim = OpenAPI_smf_selection_data_parseFromJSON(smf_sel_info);
}
cJSON *ue_ambr = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "ueAmbr");
OpenAPI_ambr_t *ue_ambr_local_nonprim = NULL;
if (ue_ambr) {
ue_ambr_local_nonprim = OpenAPI_ambr_parseFromJSON(ue_ambr);
}
cJSON *pras = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "pras");
OpenAPI_list_t *prasList;
if (pras) {
cJSON *pras_local_map;
if (!cJSON_IsObject(pras)) {
ogs_error("OpenAPI_policy_association_parseFromJSON() failed [pras]");
goto end;
}
prasList = OpenAPI_list_create();
OpenAPI_map_t *localMapKeyPair = NULL;
cJSON_ArrayForEach(pras_local_map, pras) {
cJSON *localMapObject = pras_local_map;
if (cJSON_IsObject(localMapObject)) {
localMapKeyPair = OpenAPI_map_create(
ogs_strdup(localMapObject->string), OpenAPI_presence_info_parseFromJSON(localMapObject));
} else if (cJSON_IsNull(localMapObject)) {
localMapKeyPair = OpenAPI_map_create(ogs_strdup(localMapObject->string), NULL);
} else {
ogs_error("OpenAPI_policy_association_parseFromJSON() failed [inner]");
goto end;
}
OpenAPI_list_add(prasList, localMapKeyPair);
}
}
cJSON *supp_feat = cJSON_GetObjectItemCaseSensitive(policy_associationJSON, "suppFeat");
if (!supp_feat) {
ogs_error("OpenAPI_policy_association_parseFromJSON() failed [supp_feat]");
goto end;
}
if (!cJSON_IsString(supp_feat)) {
ogs_error("OpenAPI_policy_association_parseFromJSON() failed [supp_feat]");
goto end;
}
policy_association_local_var = OpenAPI_policy_association_create (
request ? request_local_nonprim : NULL,
triggers ? triggersList : NULL,
serv_area_res ? serv_area_res_local_nonprim : NULL,
wl_serv_area_res ? wl_serv_area_res_local_nonprim : NULL,
rfsp ? true : false,
rfsp ? rfsp->valuedouble : 0,
smf_sel_info ? smf_sel_info_local_nonprim : NULL,
ue_ambr ? ue_ambr_local_nonprim : NULL,
pras ? prasList : NULL,
ogs_strdup(supp_feat->valuestring)
);
return policy_association_local_var;
end:
return NULL;
}
OpenAPI_policy_association_t *OpenAPI_policy_association_copy(OpenAPI_policy_association_t *dst, OpenAPI_policy_association_t *src)
{
cJSON *item = NULL;
char *content = NULL;
ogs_assert(src);
item = OpenAPI_policy_association_convertToJSON(src);
if (!item) {
ogs_error("OpenAPI_policy_association_convertToJSON() failed");
return NULL;
}
content = cJSON_Print(item);
cJSON_Delete(item);
if (!content) {
ogs_error("cJSON_Print() failed");
return NULL;
}
item = cJSON_Parse(content);
ogs_free(content);
if (!item) {
ogs_error("cJSON_Parse() failed");
return NULL;
}
OpenAPI_policy_association_free(dst);
dst = OpenAPI_policy_association_parseFromJSON(item);
cJSON_Delete(item);
return dst;
}