skip all the hangup code in ringing state
This commit is contained in:
parent
40f29b3886
commit
52021c80b2
|
@ -1053,32 +1053,36 @@ static int control_handler(modem_t *modem, const char *num, int op)
|
||||||
case AT_MODEM_CONTROL_ONHOOK:
|
case AT_MODEM_CONTROL_ONHOOK:
|
||||||
case AT_MODEM_CONTROL_HANGUP:
|
case AT_MODEM_CONTROL_HANGUP:
|
||||||
{
|
{
|
||||||
int set_state = 1;
|
if (modem_get_state(modem) != MODEM_STATE_RINGING) {
|
||||||
|
int set_state = 1;
|
||||||
|
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG,
|
||||||
|
"Modem %s [%s] - Hanging up\n", modem->devlink, modem_state2name(modem_get_state(modem)));
|
||||||
|
switch_clear_flag(modem, MODEM_FLAG_XOFF);
|
||||||
|
wake_modem_thread(modem);
|
||||||
|
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG,
|
modem_set_state(modem, MODEM_STATE_HANGUP);
|
||||||
"Modem %s [%s] - Hanging up\n", modem->devlink, modem_state2name(modem_get_state(modem)));
|
|
||||||
switch_clear_flag(modem, MODEM_FLAG_XOFF);
|
|
||||||
wake_modem_thread(modem);
|
|
||||||
|
|
||||||
modem_set_state(modem, MODEM_STATE_HANGUP);
|
if (!zstr(modem->uuid_str)) {
|
||||||
|
switch_core_session_t *session;
|
||||||
if (!zstr(modem->uuid_str)) {
|
|
||||||
switch_core_session_t *session;
|
if ((session = switch_core_session_force_locate(modem->uuid_str))) {
|
||||||
|
switch_channel_t *channel = switch_core_session_get_channel(session);
|
||||||
if ((session = switch_core_session_force_locate(modem->uuid_str))) {
|
|
||||||
switch_channel_t *channel = switch_core_session_get_channel(session);
|
if (switch_channel_up(channel)) {
|
||||||
|
switch_channel_hangup(channel, SWITCH_CAUSE_NORMAL_CLEARING);
|
||||||
if (switch_channel_up(channel) &&
|
set_state = 0;
|
||||||
(switch_channel_test_flag(channel, CF_ANSWERED) || switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_INBOUND)) {
|
}
|
||||||
switch_channel_hangup(channel, SWITCH_CAUSE_NORMAL_CLEARING);
|
switch_core_session_rwunlock(session);
|
||||||
set_state = 0;
|
|
||||||
}
|
}
|
||||||
switch_core_session_rwunlock(session);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (set_state) {
|
if (set_state) {
|
||||||
modem_set_state(modem, MODEM_STATE_ONHOOK);
|
modem_set_state(modem, MODEM_STATE_ONHOOK);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue