[SBI] Crash occurs when ENUM in the MAP (#2103)

This commit is contained in:
Sukchan Lee 2023-03-01 17:50:25 +09:00
parent ce668c556c
commit 969c116e77
1097 changed files with 266728 additions and 42047 deletions

View file

@ -22,22 +22,33 @@ OpenAPI_tai_range_t *OpenAPI_tai_range_create(
void OpenAPI_tai_range_free(OpenAPI_tai_range_t *tai_range)
{
OpenAPI_lnode_t *node = NULL;
if (NULL == tai_range) {
return;
}
OpenAPI_lnode_t *node;
OpenAPI_plmn_id_free(tai_range->plmn_id);
OpenAPI_list_for_each(tai_range->tac_range_list, node) {
OpenAPI_tac_range_free(node->data);
if (tai_range->plmn_id) {
OpenAPI_plmn_id_free(tai_range->plmn_id);
tai_range->plmn_id = NULL;
}
if (tai_range->tac_range_list) {
OpenAPI_list_for_each(tai_range->tac_range_list, node) {
OpenAPI_tac_range_free(node->data);
}
OpenAPI_list_free(tai_range->tac_range_list);
tai_range->tac_range_list = NULL;
}
if (tai_range->nid) {
ogs_free(tai_range->nid);
tai_range->nid = NULL;
}
OpenAPI_list_free(tai_range->tac_range_list);
ogs_free(tai_range->nid);
ogs_free(tai_range);
}
cJSON *OpenAPI_tai_range_convertToJSON(OpenAPI_tai_range_t *tai_range)
{
cJSON *item = NULL;
OpenAPI_lnode_t *node = NULL;
if (tai_range == NULL) {
ogs_error("OpenAPI_tai_range_convertToJSON() failed [TaiRange]");
@ -45,6 +56,10 @@ cJSON *OpenAPI_tai_range_convertToJSON(OpenAPI_tai_range_t *tai_range)
}
item = cJSON_CreateObject();
if (!tai_range->plmn_id) {
ogs_error("OpenAPI_tai_range_convertToJSON() failed [plmn_id]");
return NULL;
}
cJSON *plmn_id_local_JSON = OpenAPI_plmn_id_convertToJSON(tai_range->plmn_id);
if (plmn_id_local_JSON == NULL) {
ogs_error("OpenAPI_tai_range_convertToJSON() failed [plmn_id]");
@ -56,22 +71,22 @@ cJSON *OpenAPI_tai_range_convertToJSON(OpenAPI_tai_range_t *tai_range)
goto end;
}
if (!tai_range->tac_range_list) {
ogs_error("OpenAPI_tai_range_convertToJSON() failed [tac_range_list]");
return NULL;
}
cJSON *tac_range_listList = cJSON_AddArrayToObject(item, "tacRangeList");
if (tac_range_listList == NULL) {
ogs_error("OpenAPI_tai_range_convertToJSON() failed [tac_range_list]");
goto end;
}
OpenAPI_lnode_t *tac_range_list_node;
if (tai_range->tac_range_list) {
OpenAPI_list_for_each(tai_range->tac_range_list, tac_range_list_node) {
cJSON *itemLocal = OpenAPI_tac_range_convertToJSON(tac_range_list_node->data);
if (itemLocal == NULL) {
ogs_error("OpenAPI_tai_range_convertToJSON() failed [tac_range_list]");
goto end;
}
cJSON_AddItemToArray(tac_range_listList, itemLocal);
OpenAPI_list_for_each(tai_range->tac_range_list, node) {
cJSON *itemLocal = OpenAPI_tac_range_convertToJSON(node->data);
if (itemLocal == NULL) {
ogs_error("OpenAPI_tai_range_convertToJSON() failed [tac_range_list]");
goto end;
}
cJSON_AddItemToArray(tac_range_listList, itemLocal);
}
if (tai_range->nid) {
@ -88,50 +103,49 @@ end:
OpenAPI_tai_range_t *OpenAPI_tai_range_parseFromJSON(cJSON *tai_rangeJSON)
{
OpenAPI_tai_range_t *tai_range_local_var = NULL;
cJSON *plmn_id = cJSON_GetObjectItemCaseSensitive(tai_rangeJSON, "plmnId");
OpenAPI_lnode_t *node = NULL;
cJSON *plmn_id = NULL;
OpenAPI_plmn_id_t *plmn_id_local_nonprim = NULL;
cJSON *tac_range_list = NULL;
OpenAPI_list_t *tac_range_listList = NULL;
cJSON *nid = NULL;
plmn_id = cJSON_GetObjectItemCaseSensitive(tai_rangeJSON, "plmnId");
if (!plmn_id) {
ogs_error("OpenAPI_tai_range_parseFromJSON() failed [plmn_id]");
goto end;
}
OpenAPI_plmn_id_t *plmn_id_local_nonprim = NULL;
plmn_id_local_nonprim = OpenAPI_plmn_id_parseFromJSON(plmn_id);
cJSON *tac_range_list = cJSON_GetObjectItemCaseSensitive(tai_rangeJSON, "tacRangeList");
tac_range_list = cJSON_GetObjectItemCaseSensitive(tai_rangeJSON, "tacRangeList");
if (!tac_range_list) {
ogs_error("OpenAPI_tai_range_parseFromJSON() failed [tac_range_list]");
goto end;
}
OpenAPI_list_t *tac_range_listList;
cJSON *tac_range_list_local_nonprimitive;
if (!cJSON_IsArray(tac_range_list)){
ogs_error("OpenAPI_tai_range_parseFromJSON() failed [tac_range_list]");
goto end;
}
tac_range_listList = OpenAPI_list_create();
cJSON_ArrayForEach(tac_range_list_local_nonprimitive, tac_range_list ) {
if (!cJSON_IsObject(tac_range_list_local_nonprimitive)) {
cJSON *tac_range_list_local = NULL;
if (!cJSON_IsArray(tac_range_list)) {
ogs_error("OpenAPI_tai_range_parseFromJSON() failed [tac_range_list]");
goto end;
}
OpenAPI_tac_range_t *tac_range_listItem = OpenAPI_tac_range_parseFromJSON(tac_range_list_local_nonprimitive);
if (!tac_range_listItem) {
ogs_error("No tac_range_listItem");
OpenAPI_list_free(tac_range_listList);
goto end;
tac_range_listList = OpenAPI_list_create();
cJSON_ArrayForEach(tac_range_list_local, tac_range_list) {
if (!cJSON_IsObject(tac_range_list_local)) {
ogs_error("OpenAPI_tai_range_parseFromJSON() failed [tac_range_list]");
goto end;
}
OpenAPI_tac_range_t *tac_range_listItem = OpenAPI_tac_range_parseFromJSON(tac_range_list_local);
if (!tac_range_listItem) {
ogs_error("No tac_range_listItem");
OpenAPI_list_free(tac_range_listList);
goto end;
}
OpenAPI_list_add(tac_range_listList, tac_range_listItem);
}
OpenAPI_list_add(tac_range_listList, tac_range_listItem);
}
cJSON *nid = cJSON_GetObjectItemCaseSensitive(tai_rangeJSON, "nid");
nid = cJSON_GetObjectItemCaseSensitive(tai_rangeJSON, "nid");
if (nid) {
if (!cJSON_IsString(nid)) {
if (!cJSON_IsString(nid) && !cJSON_IsNull(nid)) {
ogs_error("OpenAPI_tai_range_parseFromJSON() failed [nid]");
goto end;
}
@ -140,11 +154,22 @@ OpenAPI_tai_range_t *OpenAPI_tai_range_parseFromJSON(cJSON *tai_rangeJSON)
tai_range_local_var = OpenAPI_tai_range_create (
plmn_id_local_nonprim,
tac_range_listList,
nid ? ogs_strdup(nid->valuestring) : NULL
nid && !cJSON_IsNull(nid) ? ogs_strdup(nid->valuestring) : NULL
);
return tai_range_local_var;
end:
if (plmn_id_local_nonprim) {
OpenAPI_plmn_id_free(plmn_id_local_nonprim);
plmn_id_local_nonprim = NULL;
}
if (tac_range_listList) {
OpenAPI_list_for_each(tac_range_listList, node) {
OpenAPI_tac_range_free(node->data);
}
OpenAPI_list_free(tac_range_listList);
tac_range_listList = NULL;
}
return NULL;
}