add dtmf based hangup (OPENZAP-3)
git-svn-id: http://svn.openzap.org/svn/openzap/trunk@571 a93c3328-9c30-0410-af19-c9cd2b2d52af
This commit is contained in:
parent
0fefb95b07
commit
b89f93c049
|
@ -426,6 +426,7 @@ struct zap_channel {
|
||||||
zap_buffer_t *fsk_buffer;
|
zap_buffer_t *fsk_buffer;
|
||||||
uint32_t dtmf_on;
|
uint32_t dtmf_on;
|
||||||
uint32_t dtmf_off;
|
uint32_t dtmf_off;
|
||||||
|
char *dtmf_hangup_buf;
|
||||||
teletone_generation_session_t tone_session;
|
teletone_generation_session_t tone_session;
|
||||||
zap_time_t last_event_time;
|
zap_time_t last_event_time;
|
||||||
zap_time_t ring_time;
|
zap_time_t ring_time;
|
||||||
|
@ -489,6 +490,8 @@ struct zap_span {
|
||||||
zap_span_start_t start;
|
zap_span_start_t start;
|
||||||
void *mod_data;
|
void *mod_data;
|
||||||
char *type;
|
char *type;
|
||||||
|
char *dtmf_hangup;
|
||||||
|
size_t dtmf_hangup_len;
|
||||||
int suggest_chan_id;
|
int suggest_chan_id;
|
||||||
zap_state_map_t *state_map;
|
zap_state_map_t *state_map;
|
||||||
};
|
};
|
||||||
|
|
|
@ -222,6 +222,7 @@ static zap_status_t zap_span_destroy(zap_span_t *span)
|
||||||
zap_log(ZAP_LOG_INFO, "Destroying span %u type (%s)\n", span->span_id, span->type);
|
zap_log(ZAP_LOG_INFO, "Destroying span %u type (%s)\n", span->span_id, span->type);
|
||||||
status = span->zio->span_destroy(span);
|
status = span->zio->span_destroy(span);
|
||||||
zap_safe_free(span->type);
|
zap_safe_free(span->type);
|
||||||
|
zap_safe_free(span->dtmf_hangup);
|
||||||
}
|
}
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
|
@ -241,6 +242,8 @@ static zap_status_t zap_channel_destroy(zap_channel_t *zchan)
|
||||||
zap_buffer_destroy(&zchan->dtmf_buffer);
|
zap_buffer_destroy(&zchan->dtmf_buffer);
|
||||||
zap_buffer_destroy(&zchan->fsk_buffer);
|
zap_buffer_destroy(&zchan->fsk_buffer);
|
||||||
|
|
||||||
|
zap_safe_free(zchan->dtmf_hangup_buf);
|
||||||
|
|
||||||
if (zchan->tone_session.buffer) {
|
if (zchan->tone_session.buffer) {
|
||||||
teletone_destroy_session(&zchan->tone_session);
|
teletone_destroy_session(&zchan->tone_session);
|
||||||
memset(&zchan->tone_session, 0, sizeof(zchan->tone_session));
|
memset(&zchan->tone_session, 0, sizeof(zchan->tone_session));
|
||||||
|
@ -453,6 +456,8 @@ zap_status_t zap_span_add_channel(zap_span_t *span, zap_socket_t sockfd, zap_cha
|
||||||
zap_mutex_create(&new_chan->mutex);
|
zap_mutex_create(&new_chan->mutex);
|
||||||
zap_buffer_create(&new_chan->digit_buffer, 128, 128, 0);
|
zap_buffer_create(&new_chan->digit_buffer, 128, 128, 0);
|
||||||
|
|
||||||
|
new_chan->dtmf_hangup_buf = calloc (span->dtmf_hangup_len + 1, sizeof (char));
|
||||||
|
|
||||||
zap_set_flag(new_chan, ZAP_CHANNEL_CONFIGURED | ZAP_CHANNEL_READY);
|
zap_set_flag(new_chan, ZAP_CHANNEL_CONFIGURED | ZAP_CHANNEL_READY);
|
||||||
*chan = new_chan;
|
*chan = new_chan;
|
||||||
return ZAP_SUCCESS;
|
return ZAP_SUCCESS;
|
||||||
|
@ -965,6 +970,8 @@ static zap_status_t zap_channel_reset(zap_channel_t *zchan)
|
||||||
zchan->dtmf_off = ZAP_DEFAULT_DTMF_OFF;
|
zchan->dtmf_off = ZAP_DEFAULT_DTMF_OFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
memset(zchan->dtmf_hangup_buf, '\0', zchan->span->dtmf_hangup_len);
|
||||||
|
|
||||||
if (zap_test_flag(zchan, ZAP_CHANNEL_TRANSCODE)) {
|
if (zap_test_flag(zchan, ZAP_CHANNEL_TRANSCODE)) {
|
||||||
zchan->effective_codec = zchan->native_codec;
|
zchan->effective_codec = zchan->native_codec;
|
||||||
zchan->packet_len = zchan->native_interval * (zchan->effective_codec == ZAP_CODEC_SLIN ? 16 : 8);
|
zchan->packet_len = zchan->native_interval * (zchan->effective_codec == ZAP_CODEC_SLIN ? 16 : 8);
|
||||||
|
@ -1656,6 +1663,18 @@ zap_status_t zap_channel_queue_dtmf(zap_channel_t *zchan, const char *dtmf)
|
||||||
zap_buffer_toss(zchan->digit_buffer, strlen(dtmf));
|
zap_buffer_toss(zchan->digit_buffer, strlen(dtmf));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (zchan->span->dtmf_hangup_len) {
|
||||||
|
for (p = dtmf; zap_is_dtmf(*p); p++) {
|
||||||
|
memmove (zchan->dtmf_hangup_buf, zchan->dtmf_hangup_buf + 1, zchan->span->dtmf_hangup_len - 1);
|
||||||
|
zchan->dtmf_hangup_buf[zchan->span->dtmf_hangup_len - 1] = *p;
|
||||||
|
if (!strcmp(zchan->dtmf_hangup_buf, zchan->span->dtmf_hangup)) {
|
||||||
|
zap_log(ZAP_LOG_DEBUG, "DTMF hangup detected.\n");
|
||||||
|
zap_set_state_locked(zchan, ZAP_CHANNEL_STATE_HANGUP);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
p = dtmf;
|
p = dtmf;
|
||||||
while (wr < len && p) {
|
while (wr < len && p) {
|
||||||
if (zap_is_dtmf(*p)) {
|
if (zap_is_dtmf(*p)) {
|
||||||
|
@ -2127,6 +2146,9 @@ static zap_status_t load_config(void)
|
||||||
configured += zio->configure_span(span, val, qtype, name, number);
|
configured += zio->configure_span(span, val, qtype, name, number);
|
||||||
d++;
|
d++;
|
||||||
}
|
}
|
||||||
|
} else if (!strcasecmp(var, "dtmf_hangup")) {
|
||||||
|
span->dtmf_hangup = strdup(val);
|
||||||
|
span->dtmf_hangup_len = strlen(val);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
zap_log(ZAP_LOG_ERROR, "unknown param [%s] '%s' / '%s'\n", cfg.category, var, val);
|
zap_log(ZAP_LOG_ERROR, "unknown param [%s] '%s' / '%s'\n", cfg.category, var, val);
|
||||||
|
|
Loading…
Reference in New Issue