IRC-00 refactor how record_answer_req=true works, add media_bug_answer_req=true variable and backport record_answer_req=true to use it
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@15235 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
7fbdde93b6
commit
eeb3f0b225
|
@ -1120,7 +1120,7 @@ typedef enum {
|
||||||
SMBF_READ_REPLACE = (1 << 3),
|
SMBF_READ_REPLACE = (1 << 3),
|
||||||
SMBF_READ_PING = (1 << 4),
|
SMBF_READ_PING = (1 << 4),
|
||||||
SMBF_STEREO = (1 << 5),
|
SMBF_STEREO = (1 << 5),
|
||||||
SMBF_RECORD_ANSWER_REQ = (1 << 6),
|
SMBF_ANSWER_REQ = (1 << 6),
|
||||||
SMBF_THREAD_LOCK = (1 << 7)
|
SMBF_THREAD_LOCK = (1 << 7)
|
||||||
} switch_media_bug_flag_enum_t;
|
} switch_media_bug_flag_enum_t;
|
||||||
typedef uint32_t switch_media_bug_flag_t;
|
typedef uint32_t switch_media_bug_flag_t;
|
||||||
|
|
|
@ -334,6 +334,10 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_read_frame(switch_core_sessi
|
||||||
switch_bool_t ok = SWITCH_TRUE;
|
switch_bool_t ok = SWITCH_TRUE;
|
||||||
switch_thread_rwlock_rdlock(session->bug_rwlock);
|
switch_thread_rwlock_rdlock(session->bug_rwlock);
|
||||||
for (bp = session->bugs; bp; bp = bp->next) {
|
for (bp = session->bugs; bp; bp = bp->next) {
|
||||||
|
if (!switch_channel_test_flag(session->channel, CF_ANSWERED) && switch_core_media_bug_test_flag(bp, SMBF_ANSWER_REQ)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (bp->ready && switch_test_flag(bp, SMBF_READ_STREAM)) {
|
if (bp->ready && switch_test_flag(bp, SMBF_READ_STREAM)) {
|
||||||
switch_mutex_lock(bp->read_mutex);
|
switch_mutex_lock(bp->read_mutex);
|
||||||
switch_buffer_write(bp->raw_read_buffer, read_frame->data, read_frame->datalen);
|
switch_buffer_write(bp->raw_read_buffer, read_frame->data, read_frame->datalen);
|
||||||
|
@ -496,6 +500,10 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_read_frame(switch_core_sessi
|
||||||
switch_bool_t ok = SWITCH_TRUE;
|
switch_bool_t ok = SWITCH_TRUE;
|
||||||
switch_thread_rwlock_rdlock(session->bug_rwlock);
|
switch_thread_rwlock_rdlock(session->bug_rwlock);
|
||||||
for (bp = session->bugs; bp; bp = bp->next) {
|
for (bp = session->bugs; bp; bp = bp->next) {
|
||||||
|
if (!switch_channel_test_flag(session->channel, CF_ANSWERED) && switch_core_media_bug_test_flag(bp, SMBF_ANSWER_REQ)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (bp->ready && switch_test_flag(bp, SMBF_READ_PING)) {
|
if (bp->ready && switch_test_flag(bp, SMBF_READ_PING)) {
|
||||||
switch_mutex_lock(bp->read_mutex);
|
switch_mutex_lock(bp->read_mutex);
|
||||||
if (bp->callback) {
|
if (bp->callback) {
|
||||||
|
@ -760,6 +768,11 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_write_frame(switch_core_sess
|
||||||
if (!bp->ready) {
|
if (!bp->ready) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!switch_channel_test_flag(session->channel, CF_ANSWERED) && switch_core_media_bug_test_flag(bp, SMBF_ANSWER_REQ)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (switch_test_flag(bp, SMBF_WRITE_STREAM)) {
|
if (switch_test_flag(bp, SMBF_WRITE_STREAM)) {
|
||||||
|
|
||||||
switch_mutex_lock(bp->write_mutex);
|
switch_mutex_lock(bp->write_mutex);
|
||||||
|
|
|
@ -235,7 +235,7 @@ SWITCH_DECLARE(switch_status_t) switch_core_media_bug_add(switch_core_session_t
|
||||||
switch_size_t bytes;
|
switch_size_t bytes;
|
||||||
switch_codec_implementation_t read_impl = {0};
|
switch_codec_implementation_t read_impl = {0};
|
||||||
switch_codec_implementation_t write_impl = {0};
|
switch_codec_implementation_t write_impl = {0};
|
||||||
|
const char *p;
|
||||||
|
|
||||||
if (!switch_channel_media_ready(session->channel)) {
|
if (!switch_channel_media_ready(session->channel)) {
|
||||||
if (switch_channel_pre_answer(session->channel) != SWITCH_STATUS_SUCCESS) {
|
if (switch_channel_pre_answer(session->channel) != SWITCH_STATUS_SUCCESS) {
|
||||||
|
@ -248,6 +248,11 @@ SWITCH_DECLARE(switch_status_t) switch_core_media_bug_add(switch_core_session_t
|
||||||
|
|
||||||
*new_bug = NULL;
|
*new_bug = NULL;
|
||||||
|
|
||||||
|
|
||||||
|
if ((p = switch_channel_get_variable(session->channel, "media_bug_answer_req")) && switch_true(p)) {
|
||||||
|
flags |= SMBF_ANSWER_REQ;
|
||||||
|
}
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if (flags & SMBF_WRITE_REPLACE) {
|
if (flags & SMBF_WRITE_REPLACE) {
|
||||||
switch_thread_rwlock_wrlock(session->bug_rwlock);
|
switch_thread_rwlock_wrlock(session->bug_rwlock);
|
||||||
|
|
|
@ -459,20 +459,18 @@ static switch_bool_t record_callback(switch_media_bug_t *bug, void *user_data, s
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rh->fh) {
|
if (rh->fh) {
|
||||||
if (switch_channel_test_flag(channel, CF_ANSWERED) || !switch_core_media_bug_test_flag(bug, SMBF_RECORD_ANSWER_REQ)) {
|
switch_size_t len;
|
||||||
switch_size_t len;
|
uint8_t data[SWITCH_RECOMMENDED_BUFFER_SIZE];
|
||||||
uint8_t data[SWITCH_RECOMMENDED_BUFFER_SIZE];
|
switch_frame_t frame = { 0 };
|
||||||
switch_frame_t frame = { 0 };
|
|
||||||
|
|
||||||
|
frame.data = data;
|
||||||
|
frame.buflen = SWITCH_RECOMMENDED_BUFFER_SIZE;
|
||||||
|
|
||||||
frame.data = data;
|
while (switch_core_media_bug_read(bug, &frame, SWITCH_TRUE) == SWITCH_STATUS_SUCCESS && !switch_test_flag((&frame), SFF_CNG)) {
|
||||||
frame.buflen = SWITCH_RECOMMENDED_BUFFER_SIZE;
|
len = (switch_size_t) frame.datalen / 2;
|
||||||
|
if (len) switch_core_file_write(rh->fh, data, &len);
|
||||||
while (switch_core_media_bug_read(bug, &frame, SWITCH_TRUE) == SWITCH_STATUS_SUCCESS && !switch_test_flag((&frame), SFF_CNG)) {
|
|
||||||
len = (switch_size_t) frame.datalen / 2;
|
|
||||||
if (len) switch_core_file_write(rh->fh, data, &len);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
switch_core_file_close(rh->fh);
|
switch_core_file_close(rh->fh);
|
||||||
if (rh->fh->samples_out < read_impl.samples_per_second * 3) {
|
if (rh->fh->samples_out < read_impl.samples_per_second * 3) {
|
||||||
|
@ -493,12 +491,11 @@ static switch_bool_t record_callback(switch_media_bug_t *bug, void *user_data, s
|
||||||
frame.data = data;
|
frame.data = data;
|
||||||
frame.buflen = SWITCH_RECOMMENDED_BUFFER_SIZE;
|
frame.buflen = SWITCH_RECOMMENDED_BUFFER_SIZE;
|
||||||
|
|
||||||
if (switch_channel_test_flag(channel, CF_ANSWERED) || !switch_core_media_bug_test_flag(bug, SMBF_RECORD_ANSWER_REQ)) {
|
while (switch_core_media_bug_read(bug, &frame, SWITCH_TRUE) == SWITCH_STATUS_SUCCESS && !switch_test_flag((&frame), SFF_CNG)) {
|
||||||
while (switch_core_media_bug_read(bug, &frame, SWITCH_TRUE) == SWITCH_STATUS_SUCCESS && !switch_test_flag((&frame), SFF_CNG)) {
|
len = (switch_size_t) frame.datalen / 2;
|
||||||
len = (switch_size_t) frame.datalen / 2;
|
if (len) switch_core_file_write(rh->fh, data, &len);
|
||||||
if (len) switch_core_file_write(rh->fh, data, &len);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case SWITCH_ABC_TYPE_WRITE:
|
case SWITCH_ABC_TYPE_WRITE:
|
||||||
|
@ -911,7 +908,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_record_session(switch_core_session_t
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((p = switch_channel_get_variable(channel, "RECORD_ANSWER_REQ")) && switch_true(p)) {
|
if ((p = switch_channel_get_variable(channel, "RECORD_ANSWER_REQ")) && switch_true(p)) {
|
||||||
flags |= SMBF_RECORD_ANSWER_REQ;
|
flags |= SMBF_ANSWER_REQ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue