#include #include #include #include "am_policy_data.h" OpenAPI_am_policy_data_t *OpenAPI_am_policy_data_create( OpenAPI_list_t* pra_infos, OpenAPI_list_t *subsc_cats ) { OpenAPI_am_policy_data_t *am_policy_data_local_var = ogs_malloc(sizeof(OpenAPI_am_policy_data_t)); ogs_assert(am_policy_data_local_var); am_policy_data_local_var->pra_infos = pra_infos; am_policy_data_local_var->subsc_cats = subsc_cats; return am_policy_data_local_var; } void OpenAPI_am_policy_data_free(OpenAPI_am_policy_data_t *am_policy_data) { if (NULL == am_policy_data) { return; } OpenAPI_lnode_t *node; OpenAPI_list_for_each(am_policy_data->pra_infos, node) { OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)node->data; ogs_free(localKeyValue->key); OpenAPI_presence_info_free(localKeyValue->value); ogs_free(localKeyValue); } OpenAPI_list_free(am_policy_data->pra_infos); OpenAPI_list_for_each(am_policy_data->subsc_cats, node) { ogs_free(node->data); } OpenAPI_list_free(am_policy_data->subsc_cats); ogs_free(am_policy_data); } cJSON *OpenAPI_am_policy_data_convertToJSON(OpenAPI_am_policy_data_t *am_policy_data) { cJSON *item = NULL; if (am_policy_data == NULL) { ogs_error("OpenAPI_am_policy_data_convertToJSON() failed [AmPolicyData]"); return NULL; } item = cJSON_CreateObject(); if (am_policy_data->pra_infos) { cJSON *pra_infos = cJSON_AddObjectToObject(item, "praInfos"); if (pra_infos == NULL) { ogs_error("OpenAPI_am_policy_data_convertToJSON() failed [pra_infos]"); goto end; } cJSON *localMapObject = pra_infos; OpenAPI_lnode_t *pra_infos_node; if (am_policy_data->pra_infos) { OpenAPI_list_for_each(am_policy_data->pra_infos, pra_infos_node) { OpenAPI_map_t *localKeyValue = (OpenAPI_map_t*)pra_infos_node->data; cJSON *itemLocal = localKeyValue->value ? OpenAPI_presence_info_convertToJSON(localKeyValue->value) : cJSON_CreateNull(); if (itemLocal == NULL) { ogs_error("OpenAPI_am_policy_data_convertToJSON() failed [inner]"); goto end; } cJSON_AddItemToObject(localMapObject, localKeyValue->key, itemLocal); } } } if (am_policy_data->subsc_cats) { cJSON *subsc_cats = cJSON_AddArrayToObject(item, "subscCats"); if (subsc_cats == NULL) { ogs_error("OpenAPI_am_policy_data_convertToJSON() failed [subsc_cats]"); goto end; } OpenAPI_lnode_t *subsc_cats_node; OpenAPI_list_for_each(am_policy_data->subsc_cats, subsc_cats_node) { if (cJSON_AddStringToObject(subsc_cats, "", (char*)subsc_cats_node->data) == NULL) { ogs_error("OpenAPI_am_policy_data_convertToJSON() failed [subsc_cats]"); goto end; } } } end: return item; } OpenAPI_am_policy_data_t *OpenAPI_am_policy_data_parseFromJSON(cJSON *am_policy_dataJSON) { OpenAPI_am_policy_data_t *am_policy_data_local_var = NULL; cJSON *pra_infos = cJSON_GetObjectItemCaseSensitive(am_policy_dataJSON, "praInfos"); OpenAPI_list_t *pra_infosList; if (pra_infos) { cJSON *pra_infos_local_map; if (!cJSON_IsObject(pra_infos)) { ogs_error("OpenAPI_am_policy_data_parseFromJSON() failed [pra_infos]"); goto end; } pra_infosList = OpenAPI_list_create(); OpenAPI_map_t *localMapKeyPair = NULL; cJSON_ArrayForEach(pra_infos_local_map, pra_infos) { cJSON *localMapObject = pra_infos_local_map; if (cJSON_IsObject(localMapObject)) { localMapKeyPair = OpenAPI_map_create( ogs_strdup(localMapObject->string), OpenAPI_presence_info_parseFromJSON(localMapObject)); } else if (cJSON_IsNull(localMapObject)) { localMapKeyPair = OpenAPI_map_create(ogs_strdup(localMapObject->string), NULL); } else { ogs_error("OpenAPI_am_policy_data_parseFromJSON() failed [inner]"); goto end; } OpenAPI_list_add(pra_infosList, localMapKeyPair); } } cJSON *subsc_cats = cJSON_GetObjectItemCaseSensitive(am_policy_dataJSON, "subscCats"); OpenAPI_list_t *subsc_catsList; if (subsc_cats) { cJSON *subsc_cats_local; if (!cJSON_IsArray(subsc_cats)) { ogs_error("OpenAPI_am_policy_data_parseFromJSON() failed [subsc_cats]"); goto end; } subsc_catsList = OpenAPI_list_create(); cJSON_ArrayForEach(subsc_cats_local, subsc_cats) { if (!cJSON_IsString(subsc_cats_local)) { ogs_error("OpenAPI_am_policy_data_parseFromJSON() failed [subsc_cats]"); goto end; } OpenAPI_list_add(subsc_catsList, ogs_strdup(subsc_cats_local->valuestring)); } } am_policy_data_local_var = OpenAPI_am_policy_data_create ( pra_infos ? pra_infosList : NULL, subsc_cats ? subsc_catsList : NULL ); return am_policy_data_local_var; end: return NULL; } OpenAPI_am_policy_data_t *OpenAPI_am_policy_data_copy(OpenAPI_am_policy_data_t *dst, OpenAPI_am_policy_data_t *src) { cJSON *item = NULL; char *content = NULL; ogs_assert(src); item = OpenAPI_am_policy_data_convertToJSON(src); if (!item) { ogs_error("OpenAPI_am_policy_data_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_am_policy_data_free(dst); dst = OpenAPI_am_policy_data_parseFromJSON(item); cJSON_Delete(item); return dst; }