group_confirm_cancel_timeout=true to stop timers once a group_confirm is triggered LIST-001 RAY-007 IRC-1234

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@14247 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2009-07-14 17:19:14 +00:00
parent 861660360d
commit bdf8f594cc
1 changed files with 15 additions and 0 deletions

View File

@ -109,6 +109,7 @@ typedef struct {
uint8_t ignore_ring_ready; uint8_t ignore_ring_ready;
int monitor_early_media_ring_count; int monitor_early_media_ring_count;
int monitor_early_media_ring_total; int monitor_early_media_ring_total;
int cancel_timeout;
} originate_global_t; } originate_global_t;
@ -228,6 +229,10 @@ static int check_per_channel_timeouts(originate_global_t *oglobals,
int x = 0,i; int x = 0,i;
time_t elapsed = switch_epoch_time_now(NULL) - start; time_t elapsed = switch_epoch_time_now(NULL) - start;
if (oglobals->cancel_timeout > 0) {
return 0;
}
for (i = 0; i < max; i++) { for (i = 0; i < max; i++) {
if (originate_status[i].peer_channel && originate_status[i].per_channel_delay_start && elapsed > originate_status[i].per_channel_delay_start) { if (originate_status[i].peer_channel && originate_status[i].per_channel_delay_start && elapsed > originate_status[i].per_channel_delay_start) {
switch_channel_clear_flag(originate_status[i].peer_channel, CF_BLOCK_STATE); switch_channel_clear_flag(originate_status[i].peer_channel, CF_BLOCK_STATE);
@ -508,6 +513,10 @@ static uint8_t check_channel_status(originate_global_t *oglobals, originate_stat
if (!switch_strlen_zero(oglobals->key)) { if (!switch_strlen_zero(oglobals->key)) {
struct key_collect *collect; struct key_collect *collect;
if (oglobals->cancel_timeout < 0) {
oglobals->cancel_timeout = 1;
}
if ((collect = switch_core_session_alloc(originate_status[i].peer_session, sizeof(*collect)))) { if ((collect = switch_core_session_alloc(originate_status[i].peer_session, sizeof(*collect)))) {
switch_channel_set_flag(originate_status[i].peer_channel, CF_TAGGED); switch_channel_set_flag(originate_status[i].peer_channel, CF_TAGGED);
if (!switch_strlen_zero(oglobals->key)) { if (!switch_strlen_zero(oglobals->key)) {
@ -1047,6 +1056,8 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_originate(switch_core_session_t *sess
ok = 1; ok = 1;
} else if (!strcasecmp((char *) hi->name, "group_confirm_file")) { } else if (!strcasecmp((char *) hi->name, "group_confirm_file")) {
ok = 1; ok = 1;
} else if (!strcasecmp((char *) hi->name, "group_confirm_clear_timeout")) {
ok = 1;
} else if (!strcasecmp((char *) hi->name, "forked_dial")) { } else if (!strcasecmp((char *) hi->name, "forked_dial")) {
ok = 1; ok = 1;
} else if (!strcasecmp((char *) hi->name, "fail_on_single_reject")) { } else if (!strcasecmp((char *) hi->name, "fail_on_single_reject")) {
@ -1123,6 +1134,10 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_originate(switch_core_session_t *sess
oglobals.early_ok = 0; oglobals.early_ok = 0;
} }
if (switch_true(switch_event_get_header(var_event, "group_confirm_cancel_timeout"))) {
oglobals.cancel_timeout = -1;
}
if ((var = switch_event_get_header(var_event, "group_confirm_key"))) { if ((var = switch_event_get_header(var_event, "group_confirm_key"))) {
switch_copy_string(oglobals.key, var, sizeof(oglobals.key)); switch_copy_string(oglobals.key, var, sizeof(oglobals.key));
if ((var = switch_event_get_header(var_event, "group_confirm_file"))) { if ((var = switch_event_get_header(var_event, "group_confirm_file"))) {