[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

@ -24,18 +24,26 @@ OpenAPI_ue_context_release_t *OpenAPI_ue_context_release_create(
void OpenAPI_ue_context_release_free(OpenAPI_ue_context_release_t *ue_context_release)
{
OpenAPI_lnode_t *node = NULL;
if (NULL == ue_context_release) {
return;
}
OpenAPI_lnode_t *node;
ogs_free(ue_context_release->supi);
OpenAPI_ng_ap_cause_free(ue_context_release->ngap_cause);
if (ue_context_release->supi) {
ogs_free(ue_context_release->supi);
ue_context_release->supi = NULL;
}
if (ue_context_release->ngap_cause) {
OpenAPI_ng_ap_cause_free(ue_context_release->ngap_cause);
ue_context_release->ngap_cause = NULL;
}
ogs_free(ue_context_release);
}
cJSON *OpenAPI_ue_context_release_convertToJSON(OpenAPI_ue_context_release_t *ue_context_release)
{
cJSON *item = NULL;
OpenAPI_lnode_t *node = NULL;
if (ue_context_release == NULL) {
ogs_error("OpenAPI_ue_context_release_convertToJSON() failed [UEContextRelease]");
@ -57,6 +65,10 @@ cJSON *OpenAPI_ue_context_release_convertToJSON(OpenAPI_ue_context_release_t *ue
}
}
if (!ue_context_release->ngap_cause) {
ogs_error("OpenAPI_ue_context_release_convertToJSON() failed [ngap_cause]");
return NULL;
}
cJSON *ngap_cause_local_JSON = OpenAPI_ng_ap_cause_convertToJSON(ue_context_release->ngap_cause);
if (ngap_cause_local_JSON == NULL) {
ogs_error("OpenAPI_ue_context_release_convertToJSON() failed [ngap_cause]");
@ -75,17 +87,20 @@ end:
OpenAPI_ue_context_release_t *OpenAPI_ue_context_release_parseFromJSON(cJSON *ue_context_releaseJSON)
{
OpenAPI_ue_context_release_t *ue_context_release_local_var = NULL;
cJSON *supi = cJSON_GetObjectItemCaseSensitive(ue_context_releaseJSON, "supi");
OpenAPI_lnode_t *node = NULL;
cJSON *supi = NULL;
cJSON *unauthenticated_supi = NULL;
cJSON *ngap_cause = NULL;
OpenAPI_ng_ap_cause_t *ngap_cause_local_nonprim = NULL;
supi = cJSON_GetObjectItemCaseSensitive(ue_context_releaseJSON, "supi");
if (supi) {
if (!cJSON_IsString(supi)) {
if (!cJSON_IsString(supi) && !cJSON_IsNull(supi)) {
ogs_error("OpenAPI_ue_context_release_parseFromJSON() failed [supi]");
goto end;
}
}
cJSON *unauthenticated_supi = cJSON_GetObjectItemCaseSensitive(ue_context_releaseJSON, "unauthenticatedSupi");
unauthenticated_supi = cJSON_GetObjectItemCaseSensitive(ue_context_releaseJSON, "unauthenticatedSupi");
if (unauthenticated_supi) {
if (!cJSON_IsBool(unauthenticated_supi)) {
ogs_error("OpenAPI_ue_context_release_parseFromJSON() failed [unauthenticated_supi]");
@ -93,17 +108,15 @@ OpenAPI_ue_context_release_t *OpenAPI_ue_context_release_parseFromJSON(cJSON *ue
}
}
cJSON *ngap_cause = cJSON_GetObjectItemCaseSensitive(ue_context_releaseJSON, "ngapCause");
ngap_cause = cJSON_GetObjectItemCaseSensitive(ue_context_releaseJSON, "ngapCause");
if (!ngap_cause) {
ogs_error("OpenAPI_ue_context_release_parseFromJSON() failed [ngap_cause]");
goto end;
}
OpenAPI_ng_ap_cause_t *ngap_cause_local_nonprim = NULL;
ngap_cause_local_nonprim = OpenAPI_ng_ap_cause_parseFromJSON(ngap_cause);
ue_context_release_local_var = OpenAPI_ue_context_release_create (
supi ? ogs_strdup(supi->valuestring) : NULL,
supi && !cJSON_IsNull(supi) ? ogs_strdup(supi->valuestring) : NULL,
unauthenticated_supi ? true : false,
unauthenticated_supi ? unauthenticated_supi->valueint : 0,
ngap_cause_local_nonprim
@ -111,6 +124,10 @@ OpenAPI_ue_context_release_t *OpenAPI_ue_context_release_parseFromJSON(cJSON *ue
return ue_context_release_local_var;
end:
if (ngap_cause_local_nonprim) {
OpenAPI_ng_ap_cause_free(ngap_cause_local_nonprim);
ngap_cause_local_nonprim = NULL;
}
return NULL;
}