chlog: Freetdm: Support for force_sending_complete (Requires libsng_isdn support)
This commit is contained in:
parent
ba496a110a
commit
346f11f81e
|
@ -252,6 +252,7 @@ typedef struct sngisdn_span_data {
|
||||||
uint8_t raw_trace_q921; /* TODO: combine with trace_flags */
|
uint8_t raw_trace_q921; /* TODO: combine with trace_flags */
|
||||||
uint8_t timer_t3;
|
uint8_t timer_t3;
|
||||||
uint8_t restart_opt;
|
uint8_t restart_opt;
|
||||||
|
uint8_t force_sending_complete;
|
||||||
char* local_numbers[SNGISDN_NUM_LOCAL_NUMBERS];
|
char* local_numbers[SNGISDN_NUM_LOCAL_NUMBERS];
|
||||||
ftdm_sched_t *sched;
|
ftdm_sched_t *sched;
|
||||||
ftdm_queue_t *event_queue;
|
ftdm_queue_t *event_queue;
|
||||||
|
|
|
@ -286,7 +286,8 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
|
||||||
signal_data->restart_opt = SNGISDN_OPT_DEFAULT;
|
signal_data->restart_opt = SNGISDN_OPT_DEFAULT;
|
||||||
signal_data->link_id = span->span_id;
|
signal_data->link_id = span->span_id;
|
||||||
signal_data->transfer_timeout = 20000;
|
signal_data->transfer_timeout = 20000;
|
||||||
signal_data->att_remove_dtmf = 1;
|
signal_data->att_remove_dtmf = SNGISDN_OPT_DEFAULT;
|
||||||
|
signal_data->force_sending_complete = SNGISDN_OPT_DEFAULT;
|
||||||
|
|
||||||
span->default_caller_data.dnis.plan = FTDM_NPI_INVALID;
|
span->default_caller_data.dnis.plan = FTDM_NPI_INVALID;
|
||||||
span->default_caller_data.dnis.type = FTDM_TON_INVALID;
|
span->default_caller_data.dnis.type = FTDM_TON_INVALID;
|
||||||
|
@ -386,6 +387,8 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
|
||||||
parse_yesno(var, val, &signal_data->raw_trace_q931);
|
parse_yesno(var, val, &signal_data->raw_trace_q931);
|
||||||
} else if (!strcasecmp(var, "q921-raw-trace")) {
|
} else if (!strcasecmp(var, "q921-raw-trace")) {
|
||||||
parse_yesno(var, val, &signal_data->raw_trace_q921);
|
parse_yesno(var, val, &signal_data->raw_trace_q921);
|
||||||
|
} else if (!strcasecmp(var, "force-sending-complete")) {
|
||||||
|
parse_yesno(var, val, &signal_data->force_sending_complete);
|
||||||
} else if (!strcasecmp(var, "early-media-override")) {
|
} else if (!strcasecmp(var, "early-media-override")) {
|
||||||
if (parse_early_media(val, span) != FTDM_SUCCESS) {
|
if (parse_early_media(val, span) != FTDM_SUCCESS) {
|
||||||
return FTDM_FAIL;
|
return FTDM_FAIL;
|
||||||
|
|
|
@ -51,9 +51,10 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
|
||||||
ftdm_mutex_unlock(g_sngisdn_data.ccs[signal_data->cc_id].mutex);
|
ftdm_mutex_unlock(g_sngisdn_data.ccs[signal_data->cc_id].mutex);
|
||||||
|
|
||||||
memset(&conEvnt, 0, sizeof(conEvnt));
|
memset(&conEvnt, 0, sizeof(conEvnt));
|
||||||
if (signal_data->switchtype == SNGISDN_SWITCH_EUROISDN) {
|
if (signal_data->switchtype == SNGISDN_SWITCH_EUROISDN || signal_data->force_sending_complete == SNGISDN_OPT_TRUE) {
|
||||||
conEvnt.sndCmplt.eh.pres = PRSNT_NODEF;
|
conEvnt.sndCmplt.eh.pres = PRSNT_NODEF;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ftdmchan->span->trunk_type == FTDM_TRUNK_BRI_PTMP &&
|
if (ftdmchan->span->trunk_type == FTDM_TRUNK_BRI_PTMP &&
|
||||||
signal_data->signalling == SNGISDN_SIGNALING_NET) {
|
signal_data->signalling == SNGISDN_SIGNALING_NET) {
|
||||||
sngisdn_info->ces = CES_MNGMNT;
|
sngisdn_info->ces = CES_MNGMNT;
|
||||||
|
|
|
@ -273,7 +273,7 @@ ftdm_status_t sngisdn_att_transfer_process_dtmf(ftdm_channel_t *ftdmchan, const
|
||||||
att_courtesy_transfer_complete(sngisdn_info, sngisdn_info->transfer_data.response);
|
att_courtesy_transfer_complete(sngisdn_info, sngisdn_info->transfer_data.response);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (signal_data->att_remove_dtmf) {
|
if (signal_data->att_remove_dtmf != SNGISDN_OPT_FALSE) {
|
||||||
/* If we return FTDM_BREAK, dtmf event is not queue'ed to user */
|
/* If we return FTDM_BREAK, dtmf event is not queue'ed to user */
|
||||||
status = FTDM_BREAK;
|
status = FTDM_BREAK;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue