add origination_cancel_key variable for a dtmf key that can abort an originating call
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@14645 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
c0dbb3e561
commit
f8b442da52
|
@ -618,6 +618,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_wait_for_answer(switch_core_session_t
|
||||||
int timelimit = 60;
|
int timelimit = 60;
|
||||||
const char *var;
|
const char *var;
|
||||||
switch_time_t start = 0;
|
switch_time_t start = 0;
|
||||||
|
const char *cancel_key = NULL;
|
||||||
|
|
||||||
switch_assert(peer_channel);
|
switch_assert(peer_channel);
|
||||||
|
|
||||||
|
@ -643,6 +644,8 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_wait_for_answer(switch_core_session_t
|
||||||
start = switch_micro_time_now();
|
start = switch_micro_time_now();
|
||||||
|
|
||||||
if (caller_channel) {
|
if (caller_channel) {
|
||||||
|
cancel_key = switch_channel_get_variable(caller_channel, "origination_cancel_key");
|
||||||
|
|
||||||
if (switch_channel_test_flag(caller_channel, CF_ANSWERED)) {
|
if (switch_channel_test_flag(caller_channel, CF_ANSWERED)) {
|
||||||
ringback_data = switch_channel_get_variable(caller_channel, "transfer_ringback");
|
ringback_data = switch_channel_get_variable(caller_channel, "transfer_ringback");
|
||||||
}
|
}
|
||||||
|
@ -758,6 +761,18 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_wait_for_answer(switch_core_session_t
|
||||||
&& !(switch_channel_test_flag(peer_channel, CF_ANSWERED) || switch_channel_test_flag(peer_channel, CF_EARLY_MEDIA))) {
|
&& !(switch_channel_test_flag(peer_channel, CF_ANSWERED) || switch_channel_test_flag(peer_channel, CF_EARLY_MEDIA))) {
|
||||||
int diff = (int) (switch_micro_time_now() - start);
|
int diff = (int) (switch_micro_time_now() - start);
|
||||||
|
|
||||||
|
if (caller_channel && cancel_key) {
|
||||||
|
if (switch_channel_has_dtmf(caller_channel)) {
|
||||||
|
switch_dtmf_t dtmf = { 0, 0 };
|
||||||
|
if (switch_channel_dequeue_dtmf(caller_channel, &dtmf) == SWITCH_STATUS_SUCCESS) {
|
||||||
|
if (dtmf.digit == *cancel_key) {
|
||||||
|
status = SWITCH_STATUS_FALSE;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (diff > timelimit) {
|
if (diff > timelimit) {
|
||||||
status = SWITCH_STATUS_TIMEOUT;
|
status = SWITCH_STATUS_TIMEOUT;
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -929,6 +944,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_originate(switch_core_session_t *sess
|
||||||
originate_global_t oglobals = { 0 };
|
originate_global_t oglobals = { 0 };
|
||||||
int cdr_total = 0;
|
int cdr_total = 0;
|
||||||
int local_clobber = 0;
|
int local_clobber = 0;
|
||||||
|
const char *cancel_key = NULL;
|
||||||
|
|
||||||
oglobals.idx = IDX_NADA;
|
oglobals.idx = IDX_NADA;
|
||||||
oglobals.early_ok = 1;
|
oglobals.early_ok = 1;
|
||||||
|
@ -1103,6 +1119,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_originate(switch_core_session_t *sess
|
||||||
|
|
||||||
if (caller_channel) { /* ringback is only useful when there is an originator */
|
if (caller_channel) { /* ringback is only useful when there is an originator */
|
||||||
ringback_data = NULL;
|
ringback_data = NULL;
|
||||||
|
cancel_key = switch_channel_get_variable(caller_channel, "origination_cancel_key");
|
||||||
|
|
||||||
if (switch_channel_test_flag(caller_channel, CF_ANSWERED)) {
|
if (switch_channel_test_flag(caller_channel, CF_ANSWERED)) {
|
||||||
ringback_data = switch_channel_get_variable(caller_channel, "transfer_ringback");
|
ringback_data = switch_channel_get_variable(caller_channel, "transfer_ringback");
|
||||||
|
@ -1871,6 +1888,18 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_originate(switch_core_session_t *sess
|
||||||
switch_status_t tstatus = SWITCH_STATUS_SUCCESS;
|
switch_status_t tstatus = SWITCH_STATUS_SUCCESS;
|
||||||
int silence = 0;
|
int silence = 0;
|
||||||
|
|
||||||
|
if (caller_channel && cancel_key) {
|
||||||
|
if (switch_channel_has_dtmf(caller_channel)) {
|
||||||
|
switch_dtmf_t dtmf = { 0, 0 };
|
||||||
|
if (switch_channel_dequeue_dtmf(caller_channel, &dtmf) == SWITCH_STATUS_SUCCESS) {
|
||||||
|
if (dtmf.digit == *cancel_key) {
|
||||||
|
oglobals.idx = IDX_TIMEOUT;
|
||||||
|
goto notready;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (switch_channel_media_ready(caller_channel)) {
|
if (switch_channel_media_ready(caller_channel)) {
|
||||||
tstatus = switch_core_session_read_frame(oglobals.session, &read_frame, SWITCH_IO_FLAG_NONE, 0);
|
tstatus = switch_core_session_read_frame(oglobals.session, &read_frame, SWITCH_IO_FLAG_NONE, 0);
|
||||||
if (!SWITCH_READ_ACCEPTABLE(tstatus)) {
|
if (!SWITCH_READ_ACCEPTABLE(tstatus)) {
|
||||||
|
|
Loading…
Reference in New Issue