arch: DB schema Changes (#796)

- New function : NSSF
- New feature : SMF selection
This commit is contained in:
Sukchan Lee 2021-03-08 21:25:09 +09:00
parent c6bfbed922
commit 9af4268bab
691 changed files with 40727 additions and 18985 deletions

View file

@ -9,7 +9,15 @@ OpenAPI_monitoring_configuration_t *OpenAPI_monitoring_configuration_create(
int immediate_flag,
OpenAPI_location_reporting_configuration_t *location_reporting_configuration,
OpenAPI_association_type_t *association_type,
OpenAPI_datalink_reporting_configuration_t *datalink_report_cfg
OpenAPI_datalink_reporting_configuration_t *datalink_report_cfg,
OpenAPI_loss_connectivity_cfg_t *loss_connectivity_cfg,
int maximum_latency,
int maximum_response_time,
int suggested_packet_num_dl,
OpenAPI_pdu_session_status_cfg_t *pdu_session_status_cfg,
OpenAPI_reachability_for_sms_configuration_t *reachability_for_sms_cfg,
char *mtc_provider_information,
char *af_id
)
{
OpenAPI_monitoring_configuration_t *monitoring_configuration_local_var = OpenAPI_malloc(sizeof(OpenAPI_monitoring_configuration_t));
@ -21,6 +29,14 @@ OpenAPI_monitoring_configuration_t *OpenAPI_monitoring_configuration_create(
monitoring_configuration_local_var->location_reporting_configuration = location_reporting_configuration;
monitoring_configuration_local_var->association_type = association_type;
monitoring_configuration_local_var->datalink_report_cfg = datalink_report_cfg;
monitoring_configuration_local_var->loss_connectivity_cfg = loss_connectivity_cfg;
monitoring_configuration_local_var->maximum_latency = maximum_latency;
monitoring_configuration_local_var->maximum_response_time = maximum_response_time;
monitoring_configuration_local_var->suggested_packet_num_dl = suggested_packet_num_dl;
monitoring_configuration_local_var->pdu_session_status_cfg = pdu_session_status_cfg;
monitoring_configuration_local_var->reachability_for_sms_cfg = reachability_for_sms_cfg;
monitoring_configuration_local_var->mtc_provider_information = mtc_provider_information;
monitoring_configuration_local_var->af_id = af_id;
return monitoring_configuration_local_var;
}
@ -35,6 +51,11 @@ void OpenAPI_monitoring_configuration_free(OpenAPI_monitoring_configuration_t *m
OpenAPI_location_reporting_configuration_free(monitoring_configuration->location_reporting_configuration);
OpenAPI_association_type_free(monitoring_configuration->association_type);
OpenAPI_datalink_reporting_configuration_free(monitoring_configuration->datalink_report_cfg);
OpenAPI_loss_connectivity_cfg_free(monitoring_configuration->loss_connectivity_cfg);
OpenAPI_pdu_session_status_cfg_free(monitoring_configuration->pdu_session_status_cfg);
OpenAPI_reachability_for_sms_configuration_free(monitoring_configuration->reachability_for_sms_cfg);
ogs_free(monitoring_configuration->mtc_provider_information);
ogs_free(monitoring_configuration->af_id);
ogs_free(monitoring_configuration);
}
@ -109,6 +130,80 @@ cJSON *OpenAPI_monitoring_configuration_convertToJSON(OpenAPI_monitoring_configu
}
}
if (monitoring_configuration->loss_connectivity_cfg) {
cJSON *loss_connectivity_cfg_local_JSON = OpenAPI_loss_connectivity_cfg_convertToJSON(monitoring_configuration->loss_connectivity_cfg);
if (loss_connectivity_cfg_local_JSON == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [loss_connectivity_cfg]");
goto end;
}
cJSON_AddItemToObject(item, "lossConnectivityCfg", loss_connectivity_cfg_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [loss_connectivity_cfg]");
goto end;
}
}
if (monitoring_configuration->maximum_latency) {
if (cJSON_AddNumberToObject(item, "maximumLatency", monitoring_configuration->maximum_latency) == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [maximum_latency]");
goto end;
}
}
if (monitoring_configuration->maximum_response_time) {
if (cJSON_AddNumberToObject(item, "maximumResponseTime", monitoring_configuration->maximum_response_time) == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [maximum_response_time]");
goto end;
}
}
if (monitoring_configuration->suggested_packet_num_dl) {
if (cJSON_AddNumberToObject(item, "suggestedPacketNumDl", monitoring_configuration->suggested_packet_num_dl) == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [suggested_packet_num_dl]");
goto end;
}
}
if (monitoring_configuration->pdu_session_status_cfg) {
cJSON *pdu_session_status_cfg_local_JSON = OpenAPI_pdu_session_status_cfg_convertToJSON(monitoring_configuration->pdu_session_status_cfg);
if (pdu_session_status_cfg_local_JSON == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [pdu_session_status_cfg]");
goto end;
}
cJSON_AddItemToObject(item, "pduSessionStatusCfg", pdu_session_status_cfg_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [pdu_session_status_cfg]");
goto end;
}
}
if (monitoring_configuration->reachability_for_sms_cfg) {
cJSON *reachability_for_sms_cfg_local_JSON = OpenAPI_reachability_for_sms_configuration_convertToJSON(monitoring_configuration->reachability_for_sms_cfg);
if (reachability_for_sms_cfg_local_JSON == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [reachability_for_sms_cfg]");
goto end;
}
cJSON_AddItemToObject(item, "reachabilityForSmsCfg", reachability_for_sms_cfg_local_JSON);
if (item->child == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [reachability_for_sms_cfg]");
goto end;
}
}
if (monitoring_configuration->mtc_provider_information) {
if (cJSON_AddStringToObject(item, "mtcProviderInformation", monitoring_configuration->mtc_provider_information) == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [mtc_provider_information]");
goto end;
}
}
if (monitoring_configuration->af_id) {
if (cJSON_AddStringToObject(item, "afId", monitoring_configuration->af_id) == NULL) {
ogs_error("OpenAPI_monitoring_configuration_convertToJSON() failed [af_id]");
goto end;
}
}
end:
return item;
}
@ -156,12 +251,86 @@ OpenAPI_monitoring_configuration_t *OpenAPI_monitoring_configuration_parseFromJS
datalink_report_cfg_local_nonprim = OpenAPI_datalink_reporting_configuration_parseFromJSON(datalink_report_cfg);
}
cJSON *loss_connectivity_cfg = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "lossConnectivityCfg");
OpenAPI_loss_connectivity_cfg_t *loss_connectivity_cfg_local_nonprim = NULL;
if (loss_connectivity_cfg) {
loss_connectivity_cfg_local_nonprim = OpenAPI_loss_connectivity_cfg_parseFromJSON(loss_connectivity_cfg);
}
cJSON *maximum_latency = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "maximumLatency");
if (maximum_latency) {
if (!cJSON_IsNumber(maximum_latency)) {
ogs_error("OpenAPI_monitoring_configuration_parseFromJSON() failed [maximum_latency]");
goto end;
}
}
cJSON *maximum_response_time = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "maximumResponseTime");
if (maximum_response_time) {
if (!cJSON_IsNumber(maximum_response_time)) {
ogs_error("OpenAPI_monitoring_configuration_parseFromJSON() failed [maximum_response_time]");
goto end;
}
}
cJSON *suggested_packet_num_dl = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "suggestedPacketNumDl");
if (suggested_packet_num_dl) {
if (!cJSON_IsNumber(suggested_packet_num_dl)) {
ogs_error("OpenAPI_monitoring_configuration_parseFromJSON() failed [suggested_packet_num_dl]");
goto end;
}
}
cJSON *pdu_session_status_cfg = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "pduSessionStatusCfg");
OpenAPI_pdu_session_status_cfg_t *pdu_session_status_cfg_local_nonprim = NULL;
if (pdu_session_status_cfg) {
pdu_session_status_cfg_local_nonprim = OpenAPI_pdu_session_status_cfg_parseFromJSON(pdu_session_status_cfg);
}
cJSON *reachability_for_sms_cfg = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "reachabilityForSmsCfg");
OpenAPI_reachability_for_sms_configuration_t *reachability_for_sms_cfg_local_nonprim = NULL;
if (reachability_for_sms_cfg) {
reachability_for_sms_cfg_local_nonprim = OpenAPI_reachability_for_sms_configuration_parseFromJSON(reachability_for_sms_cfg);
}
cJSON *mtc_provider_information = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "mtcProviderInformation");
if (mtc_provider_information) {
if (!cJSON_IsString(mtc_provider_information)) {
ogs_error("OpenAPI_monitoring_configuration_parseFromJSON() failed [mtc_provider_information]");
goto end;
}
}
cJSON *af_id = cJSON_GetObjectItemCaseSensitive(monitoring_configurationJSON, "afId");
if (af_id) {
if (!cJSON_IsString(af_id)) {
ogs_error("OpenAPI_monitoring_configuration_parseFromJSON() failed [af_id]");
goto end;
}
}
monitoring_configuration_local_var = OpenAPI_monitoring_configuration_create (
event_type_local_nonprim,
immediate_flag ? immediate_flag->valueint : 0,
location_reporting_configuration ? location_reporting_configuration_local_nonprim : NULL,
association_type ? association_type_local_nonprim : NULL,
datalink_report_cfg ? datalink_report_cfg_local_nonprim : NULL
datalink_report_cfg ? datalink_report_cfg_local_nonprim : NULL,
loss_connectivity_cfg ? loss_connectivity_cfg_local_nonprim : NULL,
maximum_latency ? maximum_latency->valuedouble : 0,
maximum_response_time ? maximum_response_time->valuedouble : 0,
suggested_packet_num_dl ? suggested_packet_num_dl->valuedouble : 0,
pdu_session_status_cfg ? pdu_session_status_cfg_local_nonprim : NULL,
reachability_for_sms_cfg ? reachability_for_sms_cfg_local_nonprim : NULL,
mtc_provider_information ? ogs_strdup(mtc_provider_information->valuestring) : NULL,
af_id ? ogs_strdup(af_id->valuestring) : NULL
);
return monitoring_configuration_local_var;