[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

@ -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;
}