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

200 lines
6.2 KiB
C

#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "gmlc_info.h"
OpenAPI_gmlc_info_t *OpenAPI_gmlc_info_create(
OpenAPI_list_t *serving_client_types,
OpenAPI_list_t *gmlc_numbers
)
{
OpenAPI_gmlc_info_t *gmlc_info_local_var = ogs_malloc(sizeof(OpenAPI_gmlc_info_t));
ogs_assert(gmlc_info_local_var);
gmlc_info_local_var->serving_client_types = serving_client_types;
gmlc_info_local_var->gmlc_numbers = gmlc_numbers;
return gmlc_info_local_var;
}
void OpenAPI_gmlc_info_free(OpenAPI_gmlc_info_t *gmlc_info)
{
OpenAPI_lnode_t *node = NULL;
if (NULL == gmlc_info) {
return;
}
if (gmlc_info->serving_client_types) {
OpenAPI_list_for_each(gmlc_info->serving_client_types, node) {
OpenAPI_external_client_type_free(node->data);
}
OpenAPI_list_free(gmlc_info->serving_client_types);
gmlc_info->serving_client_types = NULL;
}
if (gmlc_info->gmlc_numbers) {
OpenAPI_list_for_each(gmlc_info->gmlc_numbers, node) {
ogs_free(node->data);
}
OpenAPI_list_free(gmlc_info->gmlc_numbers);
gmlc_info->gmlc_numbers = NULL;
}
ogs_free(gmlc_info);
}
cJSON *OpenAPI_gmlc_info_convertToJSON(OpenAPI_gmlc_info_t *gmlc_info)
{
cJSON *item = NULL;
OpenAPI_lnode_t *node = NULL;
if (gmlc_info == NULL) {
ogs_error("OpenAPI_gmlc_info_convertToJSON() failed [GmlcInfo]");
return NULL;
}
item = cJSON_CreateObject();
if (gmlc_info->serving_client_types) {
cJSON *serving_client_typesList = cJSON_AddArrayToObject(item, "servingClientTypes");
if (serving_client_typesList == NULL) {
ogs_error("OpenAPI_gmlc_info_convertToJSON() failed [serving_client_types]");
goto end;
}
OpenAPI_list_for_each(gmlc_info->serving_client_types, node) {
cJSON *itemLocal = OpenAPI_external_client_type_convertToJSON(node->data);
if (itemLocal == NULL) {
ogs_error("OpenAPI_gmlc_info_convertToJSON() failed [serving_client_types]");
goto end;
}
cJSON_AddItemToArray(serving_client_typesList, itemLocal);
}
}
if (gmlc_info->gmlc_numbers) {
cJSON *gmlc_numbersList = cJSON_AddArrayToObject(item, "gmlcNumbers");
if (gmlc_numbersList == NULL) {
ogs_error("OpenAPI_gmlc_info_convertToJSON() failed [gmlc_numbers]");
goto end;
}
OpenAPI_list_for_each(gmlc_info->gmlc_numbers, node) {
if (cJSON_AddStringToObject(gmlc_numbersList, "", (char*)node->data) == NULL) {
ogs_error("OpenAPI_gmlc_info_convertToJSON() failed [gmlc_numbers]");
goto end;
}
}
}
end:
return item;
}
OpenAPI_gmlc_info_t *OpenAPI_gmlc_info_parseFromJSON(cJSON *gmlc_infoJSON)
{
OpenAPI_gmlc_info_t *gmlc_info_local_var = NULL;
OpenAPI_lnode_t *node = NULL;
cJSON *serving_client_types = NULL;
OpenAPI_list_t *serving_client_typesList = NULL;
cJSON *gmlc_numbers = NULL;
OpenAPI_list_t *gmlc_numbersList = NULL;
serving_client_types = cJSON_GetObjectItemCaseSensitive(gmlc_infoJSON, "servingClientTypes");
if (serving_client_types) {
cJSON *serving_client_types_local = NULL;
if (!cJSON_IsArray(serving_client_types)) {
ogs_error("OpenAPI_gmlc_info_parseFromJSON() failed [serving_client_types]");
goto end;
}
serving_client_typesList = OpenAPI_list_create();
cJSON_ArrayForEach(serving_client_types_local, serving_client_types) {
if (!cJSON_IsObject(serving_client_types_local)) {
ogs_error("OpenAPI_gmlc_info_parseFromJSON() failed [serving_client_types]");
goto end;
}
OpenAPI_external_client_type_t *serving_client_typesItem = OpenAPI_external_client_type_parseFromJSON(serving_client_types_local);
if (!serving_client_typesItem) {
ogs_error("No serving_client_typesItem");
goto end;
}
OpenAPI_list_add(serving_client_typesList, serving_client_typesItem);
}
}
gmlc_numbers = cJSON_GetObjectItemCaseSensitive(gmlc_infoJSON, "gmlcNumbers");
if (gmlc_numbers) {
cJSON *gmlc_numbers_local = NULL;
if (!cJSON_IsArray(gmlc_numbers)) {
ogs_error("OpenAPI_gmlc_info_parseFromJSON() failed [gmlc_numbers]");
goto end;
}
gmlc_numbersList = OpenAPI_list_create();
cJSON_ArrayForEach(gmlc_numbers_local, gmlc_numbers) {
double *localDouble = NULL;
int *localInt = NULL;
if (!cJSON_IsString(gmlc_numbers_local)) {
ogs_error("OpenAPI_gmlc_info_parseFromJSON() failed [gmlc_numbers]");
goto end;
}
OpenAPI_list_add(gmlc_numbersList, ogs_strdup(gmlc_numbers_local->valuestring));
}
}
gmlc_info_local_var = OpenAPI_gmlc_info_create (
serving_client_types ? serving_client_typesList : NULL,
gmlc_numbers ? gmlc_numbersList : NULL
);
return gmlc_info_local_var;
end:
if (serving_client_typesList) {
OpenAPI_list_for_each(serving_client_typesList, node) {
OpenAPI_external_client_type_free(node->data);
}
OpenAPI_list_free(serving_client_typesList);
serving_client_typesList = NULL;
}
if (gmlc_numbersList) {
OpenAPI_list_for_each(gmlc_numbersList, node) {
ogs_free(node->data);
}
OpenAPI_list_free(gmlc_numbersList);
gmlc_numbersList = NULL;
}
return NULL;
}
OpenAPI_gmlc_info_t *OpenAPI_gmlc_info_copy(OpenAPI_gmlc_info_t *dst, OpenAPI_gmlc_info_t *src)
{
cJSON *item = NULL;
char *content = NULL;
ogs_assert(src);
item = OpenAPI_gmlc_info_convertToJSON(src);
if (!item) {
ogs_error("OpenAPI_gmlc_info_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_gmlc_info_free(dst);
dst = OpenAPI_gmlc_info_parseFromJSON(item);
cJSON_Delete(item);
return dst;
}