mirror of
https://github.com/open5gs/open5gs.git
synced 2026-05-02 05:10:10 +00:00
[SBI] Crash occurs when ENUM in the MAP (#2103)
This commit is contained in:
parent
ce668c556c
commit
969c116e77
1097 changed files with 266728 additions and 42047 deletions
|
|
@ -20,24 +20,32 @@ OpenAPI_sm_policy_dnn_data_patch_t *OpenAPI_sm_policy_dnn_data_patch_create(
|
|||
|
||||
void OpenAPI_sm_policy_dnn_data_patch_free(OpenAPI_sm_policy_dnn_data_patch_t *sm_policy_dnn_data_patch)
|
||||
{
|
||||
OpenAPI_lnode_t *node = NULL;
|
||||
|
||||
if (NULL == sm_policy_dnn_data_patch) {
|
||||
return;
|
||||
}
|
||||
OpenAPI_lnode_t *node;
|
||||
ogs_free(sm_policy_dnn_data_patch->dnn);
|
||||
OpenAPI_list_for_each(sm_policy_dnn_data_patch->bdt_ref_ids, node) {
|
||||
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data;
|
||||
ogs_free(localKeyValue->key);
|
||||
ogs_free(localKeyValue->value);
|
||||
ogs_free(localKeyValue);
|
||||
if (sm_policy_dnn_data_patch->dnn) {
|
||||
ogs_free(sm_policy_dnn_data_patch->dnn);
|
||||
sm_policy_dnn_data_patch->dnn = NULL;
|
||||
}
|
||||
if (sm_policy_dnn_data_patch->bdt_ref_ids) {
|
||||
OpenAPI_list_for_each(sm_policy_dnn_data_patch->bdt_ref_ids, node) {
|
||||
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data;
|
||||
ogs_free(localKeyValue->key);
|
||||
ogs_free(localKeyValue->value);
|
||||
OpenAPI_map_free(localKeyValue);
|
||||
}
|
||||
OpenAPI_list_free(sm_policy_dnn_data_patch->bdt_ref_ids);
|
||||
sm_policy_dnn_data_patch->bdt_ref_ids = NULL;
|
||||
}
|
||||
OpenAPI_list_free(sm_policy_dnn_data_patch->bdt_ref_ids);
|
||||
ogs_free(sm_policy_dnn_data_patch);
|
||||
}
|
||||
|
||||
cJSON *OpenAPI_sm_policy_dnn_data_patch_convertToJSON(OpenAPI_sm_policy_dnn_data_patch_t *sm_policy_dnn_data_patch)
|
||||
{
|
||||
cJSON *item = NULL;
|
||||
OpenAPI_lnode_t *node = NULL;
|
||||
|
||||
if (sm_policy_dnn_data_patch == NULL) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_convertToJSON() failed [SmPolicyDnnDataPatch]");
|
||||
|
|
@ -45,6 +53,10 @@ cJSON *OpenAPI_sm_policy_dnn_data_patch_convertToJSON(OpenAPI_sm_policy_dnn_data
|
|||
}
|
||||
|
||||
item = cJSON_CreateObject();
|
||||
if (!sm_policy_dnn_data_patch->dnn) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_convertToJSON() failed [dnn]");
|
||||
return NULL;
|
||||
}
|
||||
if (cJSON_AddStringToObject(item, "dnn", sm_policy_dnn_data_patch->dnn) == NULL) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_convertToJSON() failed [dnn]");
|
||||
goto end;
|
||||
|
|
@ -57,17 +69,16 @@ cJSON *OpenAPI_sm_policy_dnn_data_patch_convertToJSON(OpenAPI_sm_policy_dnn_data
|
|||
goto end;
|
||||
}
|
||||
cJSON *localMapObject = bdt_ref_ids;
|
||||
OpenAPI_lnode_t *bdt_ref_ids_node;
|
||||
if (sm_policy_dnn_data_patch->bdt_ref_ids) {
|
||||
OpenAPI_list_for_each(sm_policy_dnn_data_patch->bdt_ref_ids, bdt_ref_ids_node) {
|
||||
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)bdt_ref_ids_node->data;
|
||||
if (cJSON_AddStringToObject(localMapObject, localKeyValue->key, (char*)localKeyValue->value) == NULL) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_convertToJSON() failed [inner]");
|
||||
goto end;
|
||||
}
|
||||
OpenAPI_list_for_each(sm_policy_dnn_data_patch->bdt_ref_ids, node) {
|
||||
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data;
|
||||
if (cJSON_AddStringToObject(localMapObject, localKeyValue->key, (char*)localKeyValue->value) == NULL) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_convertToJSON() failed [inner]");
|
||||
goto end;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
end:
|
||||
return item;
|
||||
|
|
@ -76,37 +87,42 @@ end:
|
|||
OpenAPI_sm_policy_dnn_data_patch_t *OpenAPI_sm_policy_dnn_data_patch_parseFromJSON(cJSON *sm_policy_dnn_data_patchJSON)
|
||||
{
|
||||
OpenAPI_sm_policy_dnn_data_patch_t *sm_policy_dnn_data_patch_local_var = NULL;
|
||||
cJSON *dnn = cJSON_GetObjectItemCaseSensitive(sm_policy_dnn_data_patchJSON, "dnn");
|
||||
OpenAPI_lnode_t *node = NULL;
|
||||
cJSON *dnn = NULL;
|
||||
cJSON *bdt_ref_ids = NULL;
|
||||
OpenAPI_list_t *bdt_ref_idsList = NULL;
|
||||
dnn = cJSON_GetObjectItemCaseSensitive(sm_policy_dnn_data_patchJSON, "dnn");
|
||||
if (!dnn) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_parseFromJSON() failed [dnn]");
|
||||
goto end;
|
||||
}
|
||||
|
||||
if (!cJSON_IsString(dnn)) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_parseFromJSON() failed [dnn]");
|
||||
goto end;
|
||||
}
|
||||
|
||||
cJSON *bdt_ref_ids = cJSON_GetObjectItemCaseSensitive(sm_policy_dnn_data_patchJSON, "bdtRefIds");
|
||||
|
||||
OpenAPI_list_t *bdt_ref_idsList;
|
||||
bdt_ref_ids = cJSON_GetObjectItemCaseSensitive(sm_policy_dnn_data_patchJSON, "bdtRefIds");
|
||||
if (bdt_ref_ids) {
|
||||
cJSON *bdt_ref_ids_local_map;
|
||||
if (!cJSON_IsObject(bdt_ref_ids)) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_parseFromJSON() failed [bdt_ref_ids]");
|
||||
goto end;
|
||||
}
|
||||
bdt_ref_idsList = OpenAPI_list_create();
|
||||
OpenAPI_map_t *localMapKeyPair = NULL;
|
||||
cJSON_ArrayForEach(bdt_ref_ids_local_map, bdt_ref_ids) {
|
||||
cJSON *localMapObject = bdt_ref_ids_local_map;
|
||||
if (!cJSON_IsString(localMapObject)) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_parseFromJSON() failed [inner]");
|
||||
cJSON *bdt_ref_ids_local_map = NULL;
|
||||
if (!cJSON_IsObject(bdt_ref_ids) && !cJSON_IsNull(bdt_ref_ids)) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_parseFromJSON() failed [bdt_ref_ids]");
|
||||
goto end;
|
||||
}
|
||||
localMapKeyPair = OpenAPI_map_create(ogs_strdup(localMapObject->string),ogs_strdup(localMapObject->valuestring));
|
||||
OpenAPI_list_add(bdt_ref_idsList, localMapKeyPair);
|
||||
}
|
||||
if (cJSON_IsObject(bdt_ref_ids)) {
|
||||
bdt_ref_idsList = OpenAPI_list_create();
|
||||
OpenAPI_map_t *localMapKeyPair = NULL;
|
||||
cJSON_ArrayForEach(bdt_ref_ids_local_map, bdt_ref_ids) {
|
||||
cJSON *localMapObject = bdt_ref_ids_local_map;
|
||||
double *localDouble = NULL;
|
||||
int *localInt = NULL;
|
||||
if (!cJSON_IsString(localMapObject)) {
|
||||
ogs_error("OpenAPI_sm_policy_dnn_data_patch_parseFromJSON() failed [inner]");
|
||||
goto end;
|
||||
}
|
||||
localMapKeyPair = OpenAPI_map_create(ogs_strdup(localMapObject->string), ogs_strdup(localMapObject->valuestring));
|
||||
OpenAPI_list_add(bdt_ref_idsList, localMapKeyPair);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
sm_policy_dnn_data_patch_local_var = OpenAPI_sm_policy_dnn_data_patch_create (
|
||||
|
|
@ -116,6 +132,16 @@ OpenAPI_sm_policy_dnn_data_patch_t *OpenAPI_sm_policy_dnn_data_patch_parseFromJS
|
|||
|
||||
return sm_policy_dnn_data_patch_local_var;
|
||||
end:
|
||||
if (bdt_ref_idsList) {
|
||||
OpenAPI_list_for_each(bdt_ref_idsList, node) {
|
||||
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*) node->data;
|
||||
ogs_free(localKeyValue->key);
|
||||
ogs_free(localKeyValue->value);
|
||||
OpenAPI_map_free(localKeyValue);
|
||||
}
|
||||
OpenAPI_list_free(bdt_ref_idsList);
|
||||
bdt_ref_idsList = NULL;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue