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

210 lines
6.9 KiB
C

#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "error_report.h"
OpenAPI_error_report_t *OpenAPI_error_report_create(
OpenAPI_problem_details_t *error,
OpenAPI_list_t *rule_reports,
OpenAPI_list_t *sess_rule_reports
)
{
OpenAPI_error_report_t *error_report_local_var = OpenAPI_malloc(sizeof(OpenAPI_error_report_t));
if (!error_report_local_var) {
return NULL;
}
error_report_local_var->error = error;
error_report_local_var->rule_reports = rule_reports;
error_report_local_var->sess_rule_reports = sess_rule_reports;
return error_report_local_var;
}
void OpenAPI_error_report_free(OpenAPI_error_report_t *error_report)
{
if (NULL == error_report) {
return;
}
OpenAPI_lnode_t *node;
OpenAPI_problem_details_free(error_report->error);
OpenAPI_list_for_each(error_report->rule_reports, node) {
OpenAPI_rule_report_free(node->data);
}
OpenAPI_list_free(error_report->rule_reports);
OpenAPI_list_for_each(error_report->sess_rule_reports, node) {
OpenAPI_session_rule_report_free(node->data);
}
OpenAPI_list_free(error_report->sess_rule_reports);
ogs_free(error_report);
}
cJSON *OpenAPI_error_report_convertToJSON(OpenAPI_error_report_t *error_report)
{
cJSON *item = NULL;
if (error_report == NULL) {
ogs_error("OpenAPI_error_report_convertToJSON() failed [ErrorReport]");
return NULL;
}
item = cJSON_CreateObject();
if (error_report->error) {
cJSON *error_local_JSON = OpenAPI_problem_details_convertToJSON(error_report->error);
if (error_local_JSON == NULL) {
ogs_error("OpenAPI_error_report_convertToJSON() failed [error]");
goto end;
}
cJSON_AddItemToObject(item, "error", error_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_error_report_convertToJSON() failed [error]");
goto end;
}
}
if (error_report->rule_reports) {
cJSON *rule_reportsList = cJSON_AddArrayToObject(item, "ruleReports");
if (rule_reportsList == NULL) {
ogs_error("OpenAPI_error_report_convertToJSON() failed [rule_reports]");
goto end;
}
OpenAPI_lnode_t *rule_reports_node;
if (error_report->rule_reports) {
OpenAPI_list_for_each(error_report->rule_reports, rule_reports_node) {
cJSON *itemLocal = OpenAPI_rule_report_convertToJSON(rule_reports_node->data);
if (itemLocal == NULL) {
ogs_error("OpenAPI_error_report_convertToJSON() failed [rule_reports]");
goto end;
}
cJSON_AddItemToArray(rule_reportsList, itemLocal);
}
}
}
if (error_report->sess_rule_reports) {
cJSON *sess_rule_reportsList = cJSON_AddArrayToObject(item, "sessRuleReports");
if (sess_rule_reportsList == NULL) {
ogs_error("OpenAPI_error_report_convertToJSON() failed [sess_rule_reports]");
goto end;
}
OpenAPI_lnode_t *sess_rule_reports_node;
if (error_report->sess_rule_reports) {
OpenAPI_list_for_each(error_report->sess_rule_reports, sess_rule_reports_node) {
cJSON *itemLocal = OpenAPI_session_rule_report_convertToJSON(sess_rule_reports_node->data);
if (itemLocal == NULL) {
ogs_error("OpenAPI_error_report_convertToJSON() failed [sess_rule_reports]");
goto end;
}
cJSON_AddItemToArray(sess_rule_reportsList, itemLocal);
}
}
}
end:
return item;
}
OpenAPI_error_report_t *OpenAPI_error_report_parseFromJSON(cJSON *error_reportJSON)
{
OpenAPI_error_report_t *error_report_local_var = NULL;
cJSON *error = cJSON_GetObjectItemCaseSensitive(error_reportJSON, "error");
OpenAPI_problem_details_t *error_local_nonprim = NULL;
if (error) {
error_local_nonprim = OpenAPI_problem_details_parseFromJSON(error);
}
cJSON *rule_reports = cJSON_GetObjectItemCaseSensitive(error_reportJSON, "ruleReports");
OpenAPI_list_t *rule_reportsList;
if (rule_reports) {
cJSON *rule_reports_local_nonprimitive;
if (!cJSON_IsArray(rule_reports)) {
ogs_error("OpenAPI_error_report_parseFromJSON() failed [rule_reports]");
goto end;
}
rule_reportsList = OpenAPI_list_create();
cJSON_ArrayForEach(rule_reports_local_nonprimitive, rule_reports ) {
if (!cJSON_IsObject(rule_reports_local_nonprimitive)) {
ogs_error("OpenAPI_error_report_parseFromJSON() failed [rule_reports]");
goto end;
}
OpenAPI_rule_report_t *rule_reportsItem = OpenAPI_rule_report_parseFromJSON(rule_reports_local_nonprimitive);
OpenAPI_list_add(rule_reportsList, rule_reportsItem);
}
}
cJSON *sess_rule_reports = cJSON_GetObjectItemCaseSensitive(error_reportJSON, "sessRuleReports");
OpenAPI_list_t *sess_rule_reportsList;
if (sess_rule_reports) {
cJSON *sess_rule_reports_local_nonprimitive;
if (!cJSON_IsArray(sess_rule_reports)) {
ogs_error("OpenAPI_error_report_parseFromJSON() failed [sess_rule_reports]");
goto end;
}
sess_rule_reportsList = OpenAPI_list_create();
cJSON_ArrayForEach(sess_rule_reports_local_nonprimitive, sess_rule_reports ) {
if (!cJSON_IsObject(sess_rule_reports_local_nonprimitive)) {
ogs_error("OpenAPI_error_report_parseFromJSON() failed [sess_rule_reports]");
goto end;
}
OpenAPI_session_rule_report_t *sess_rule_reportsItem = OpenAPI_session_rule_report_parseFromJSON(sess_rule_reports_local_nonprimitive);
OpenAPI_list_add(sess_rule_reportsList, sess_rule_reportsItem);
}
}
error_report_local_var = OpenAPI_error_report_create (
error ? error_local_nonprim : NULL,
rule_reports ? rule_reportsList : NULL,
sess_rule_reports ? sess_rule_reportsList : NULL
);
return error_report_local_var;
end:
return NULL;
}
OpenAPI_error_report_t *OpenAPI_error_report_copy(OpenAPI_error_report_t *dst, OpenAPI_error_report_t *src)
{
cJSON *item = NULL;
char *content = NULL;
ogs_assert(src);
item = OpenAPI_error_report_convertToJSON(src);
if (!item) {
ogs_error("OpenAPI_error_report_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_error_report_free(dst);
dst = OpenAPI_error_report_parseFromJSON(item);
cJSON_Delete(item);
return dst;
}