zap_channel_t *zchan;
if (!(zchan = find_zchan(span, (sangomabc_short_event_t*)event, 0))) {
+ if ((zchan = find_zchan(span, (sangomabc_short_event_t*)event, 1))) {
+ int r;
+ if (zchan->state == ZAP_CHANNEL_STATE_UP) {
+ zap_log(ZAP_LOG_CRIT, "ZCHAN STATE UP -> Changed to TERMINATING %d:%d\n", event->span+1,event->chan+1);
+ zap_set_state_r(zchan, ZAP_CHANNEL_STATE_TERMINATING, 0, r);
+ } else if (zap_test_sflag(zchan, SFLAG_HANGUP)) {
+ zap_log(ZAP_LOG_CRIT, "ZCHAN STATE HANGUP -> Changed to HANGUP COMPLETE %d:%d\n", event->span+1,event->chan+1);
+ zap_set_state_r(zchan, ZAP_CHANNEL_STATE_HANGUP_COMPLETE, 0, r);
+ } else {
+ zap_log(ZAP_LOG_CRIT, "ZCHAN STATE INVALID %s on IN CALL %d:%d\n", zap_channel_state2str(zchan->state),event->span+1,event->chan+1);
+
+ }
+ zap_set_sflag(zchan, SFLAG_SENT_FINAL_MSG);
+ zchan=NULL;
+ }
zap_log(ZAP_LOG_CRIT, "START CANT FIND CHAN %d:%d\n", event->span+1,event->chan+1);
goto error;
}
break;
case ZAP_COMMAND_ENABLE_ECHOCANCEL:
{
- //code me
+ err=sangoma_tdm_enable_hwec(zchan->sockfd, &tdm_api);
+ if (err) {
+ snprintf(zchan->last_error, sizeof(zchan->last_error), "HWEC Enable Failed");
+ return ZAP_FAIL;
+ }
}
break;
case ZAP_COMMAND_DISABLE_ECHOCANCEL:
{
- //code me
+ err=sangoma_tdm_disable_hwec(zchan->sockfd, &tdm_api);
+ if (err) {
+ snprintf(zchan->last_error, sizeof(zchan->last_error), "HWEC Disable Failed");
+ return ZAP_FAIL;
+ }
}
break;
case ZAP_COMMAND_ENABLE_LOOP:
{
- // code me
+#ifdef WP_API_FEATURE_LOOP
+ err=sangoma_tdm_enable_loop(zchan->sockfd, &tdm_api);
+ if (err) {
+ snprintf(zchan->last_error, sizeof(zchan->last_error), "Loop Enable Failed");
+ return ZAP_FAIL;
+ }
+#endif
}
case ZAP_COMMAND_DISABLE_LOOP:
{
- // code me
+#ifdef WP_API_FEATURE_LOOP
+ err=sangoma_tdm_disable_loop(zchan->sockfd, &tdm_api);
+ if (err) {
+ snprintf(zchan->last_error, sizeof(zchan->last_error), "Loop Disable Failed");
+ return ZAP_FAIL;
+ }
+#endif
}
case ZAP_COMMAND_SET_INTERVAL:
{