[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_cag_data_1_t *OpenAPI_cag_data_1_create(
void OpenAPI_cag_data_1_free(OpenAPI_cag_data_1_t *cag_data_1)
{
OpenAPI_lnode_t *node = NULL;
if (NULL == cag_data_1) {
return;
}
OpenAPI_lnode_t *node;
OpenAPI_list_for_each(cag_data_1->cag_infos, node) {
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data;
ogs_free(localKeyValue->key);
OpenAPI_cag_info_1_free(localKeyValue->value);
ogs_free(localKeyValue);
if (cag_data_1->cag_infos) {
OpenAPI_list_for_each(cag_data_1->cag_infos, node) {
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data;
ogs_free(localKeyValue->key);
OpenAPI_cag_info_1_free(localKeyValue->value);
OpenAPI_map_free(localKeyValue);
}
OpenAPI_list_free(cag_data_1->cag_infos);
cag_data_1->cag_infos = NULL;
}
if (cag_data_1->provisioning_time) {
ogs_free(cag_data_1->provisioning_time);
cag_data_1->provisioning_time = NULL;
}
OpenAPI_list_free(cag_data_1->cag_infos);
ogs_free(cag_data_1->provisioning_time);
ogs_free(cag_data_1);
}
cJSON *OpenAPI_cag_data_1_convertToJSON(OpenAPI_cag_data_1_t *cag_data_1)
{
cJSON *item = NULL;
OpenAPI_lnode_t *node = NULL;
if (cag_data_1 == NULL) {
ogs_error("OpenAPI_cag_data_1_convertToJSON() failed [CagData_1]");
@ -45,26 +53,29 @@ cJSON *OpenAPI_cag_data_1_convertToJSON(OpenAPI_cag_data_1_t *cag_data_1)
}
item = cJSON_CreateObject();
if (!cag_data_1->cag_infos) {
ogs_error("OpenAPI_cag_data_1_convertToJSON() failed [cag_infos]");
return NULL;
}
cJSON *cag_infos = cJSON_AddObjectToObject(item, "cagInfos");
if (cag_infos == NULL) {
ogs_error("OpenAPI_cag_data_1_convertToJSON() failed [cag_infos]");
goto end;
}
cJSON *localMapObject = cag_infos;
OpenAPI_lnode_t *cag_infos_node;
if (cag_data_1->cag_infos) {
OpenAPI_list_for_each(cag_data_1->cag_infos, cag_infos_node) {
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)cag_infos_node->data;
cJSON *itemLocal = localKeyValue->value ?
OpenAPI_cag_info_1_convertToJSON(localKeyValue->value) :
cJSON_CreateNull();
if (itemLocal == NULL) {
ogs_error("OpenAPI_cag_data_1_convertToJSON() failed [inner]");
goto end;
}
cJSON_AddItemToObject(localMapObject, localKeyValue->key, itemLocal);
OpenAPI_list_for_each(cag_data_1->cag_infos, node) {
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data;
cJSON *itemLocal = localKeyValue->value ?
OpenAPI_cag_info_1_convertToJSON(localKeyValue->value) :
cJSON_CreateNull();
if (itemLocal == NULL) {
ogs_error("OpenAPI_cag_data_1_convertToJSON() failed [inner]");
goto end;
}
cJSON_AddItemToObject(localMapObject, localKeyValue->key, itemLocal);
}
}
if (cag_data_1->provisioning_time) {
if (cJSON_AddStringToObject(item, "provisioningTime", cag_data_1->provisioning_time) == NULL) {
@ -80,38 +91,41 @@ end:
OpenAPI_cag_data_1_t *OpenAPI_cag_data_1_parseFromJSON(cJSON *cag_data_1JSON)
{
OpenAPI_cag_data_1_t *cag_data_1_local_var = NULL;
cJSON *cag_infos = cJSON_GetObjectItemCaseSensitive(cag_data_1JSON, "cagInfos");
OpenAPI_lnode_t *node = NULL;
cJSON *cag_infos = NULL;
OpenAPI_list_t *cag_infosList = NULL;
cJSON *provisioning_time = NULL;
cag_infos = cJSON_GetObjectItemCaseSensitive(cag_data_1JSON, "cagInfos");
if (!cag_infos) {
ogs_error("OpenAPI_cag_data_1_parseFromJSON() failed [cag_infos]");
goto end;
}
OpenAPI_list_t *cag_infosList;
cJSON *cag_infos_local_map;
if (!cJSON_IsObject(cag_infos)) {
ogs_error("OpenAPI_cag_data_1_parseFromJSON() failed [cag_infos]");
goto end;
}
cag_infosList = OpenAPI_list_create();
OpenAPI_map_t *localMapKeyPair = NULL;
cJSON_ArrayForEach(cag_infos_local_map, cag_infos) {
cJSON *localMapObject = cag_infos_local_map;
if (cJSON_IsObject(localMapObject)) {
localMapKeyPair = OpenAPI_map_create(
ogs_strdup(localMapObject->string), OpenAPI_cag_info_1_parseFromJSON(localMapObject));
} else if (cJSON_IsNull(localMapObject)) {
localMapKeyPair = OpenAPI_map_create(ogs_strdup(localMapObject->string), NULL);
} else {
ogs_error("OpenAPI_cag_data_1_parseFromJSON() failed [inner]");
cJSON *cag_infos_local_map = NULL;
if (!cJSON_IsObject(cag_infos) && !cJSON_IsNull(cag_infos)) {
ogs_error("OpenAPI_cag_data_1_parseFromJSON() failed [cag_infos]");
goto end;
}
OpenAPI_list_add(cag_infosList, localMapKeyPair);
}
cJSON *provisioning_time = cJSON_GetObjectItemCaseSensitive(cag_data_1JSON, "provisioningTime");
if (cJSON_IsObject(cag_infos)) {
cag_infosList = OpenAPI_list_create();
OpenAPI_map_t *localMapKeyPair = NULL;
cJSON_ArrayForEach(cag_infos_local_map, cag_infos) {
cJSON *localMapObject = cag_infos_local_map;
if (cJSON_IsObject(localMapObject)) {
localMapKeyPair = OpenAPI_map_create(
ogs_strdup(localMapObject->string), OpenAPI_cag_info_1_parseFromJSON(localMapObject));
} else if (cJSON_IsNull(localMapObject)) {
localMapKeyPair = OpenAPI_map_create(ogs_strdup(localMapObject->string), NULL);
} else {
ogs_error("OpenAPI_cag_data_1_parseFromJSON() failed [inner]");
goto end;
}
OpenAPI_list_add(cag_infosList, localMapKeyPair);
}
}
provisioning_time = cJSON_GetObjectItemCaseSensitive(cag_data_1JSON, "provisioningTime");
if (provisioning_time) {
if (!cJSON_IsString(provisioning_time)) {
if (!cJSON_IsString(provisioning_time) && !cJSON_IsNull(provisioning_time)) {
ogs_error("OpenAPI_cag_data_1_parseFromJSON() failed [provisioning_time]");
goto end;
}
@ -119,11 +133,21 @@ OpenAPI_cag_data_1_t *OpenAPI_cag_data_1_parseFromJSON(cJSON *cag_data_1JSON)
cag_data_1_local_var = OpenAPI_cag_data_1_create (
cag_infosList,
provisioning_time ? ogs_strdup(provisioning_time->valuestring) : NULL
provisioning_time && !cJSON_IsNull(provisioning_time) ? ogs_strdup(provisioning_time->valuestring) : NULL
);
return cag_data_1_local_var;
end:
if (cag_infosList) {
OpenAPI_list_for_each(cag_infosList, node) {
OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*) node->data;
ogs_free(localKeyValue->key);
OpenAPI_cag_info_1_free(localKeyValue->value);
OpenAPI_map_free(localKeyValue);
}
OpenAPI_list_free(cag_infosList);
cag_infosList = NULL;
}
return NULL;
}