mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-04-16 08:49:01 +00:00
update
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@1279 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
31e31566a5
commit
24627a7a4b
@ -55,7 +55,8 @@ typedef enum {
|
|||||||
TFLAG_VAD_OUT = ( 1 << 12),
|
TFLAG_VAD_OUT = ( 1 << 12),
|
||||||
TFLAG_VAD = ( 1 << 13),
|
TFLAG_VAD = ( 1 << 13),
|
||||||
TFLAG_DO_CAND = ( 1 << 14),
|
TFLAG_DO_CAND = ( 1 << 14),
|
||||||
TFLAG_DO_DESC = (1 << 15)
|
TFLAG_DO_DESC = (1 << 15),
|
||||||
|
TFLAG_LANADDR = (1 << 16)
|
||||||
} TFLAGS;
|
} TFLAGS;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
@ -143,27 +144,27 @@ struct rfc2833_digit {
|
|||||||
|
|
||||||
|
|
||||||
SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_dialplan, globals.dialplan)
|
SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_dialplan, globals.dialplan)
|
||||||
SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_codec_string, globals.codec_string)
|
SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_codec_string, globals.codec_string)
|
||||||
SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_codec_rates_string, globals.codec_rates_string)
|
SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_codec_rates_string, globals.codec_rates_string)
|
||||||
|
|
||||||
|
|
||||||
static switch_status channel_on_init(switch_core_session *session);
|
static switch_status channel_on_init(switch_core_session *session);
|
||||||
static switch_status channel_on_hangup(switch_core_session *session);
|
static switch_status channel_on_hangup(switch_core_session *session);
|
||||||
static switch_status channel_on_ring(switch_core_session *session);
|
static switch_status channel_on_ring(switch_core_session *session);
|
||||||
static switch_status channel_on_loopback(switch_core_session *session);
|
static switch_status channel_on_loopback(switch_core_session *session);
|
||||||
static switch_status channel_on_transmit(switch_core_session *session);
|
static switch_status channel_on_transmit(switch_core_session *session);
|
||||||
static switch_status channel_outgoing_channel(switch_core_session *session, switch_caller_profile *outbound_profile,
|
static switch_status channel_outgoing_channel(switch_core_session *session, switch_caller_profile *outbound_profile,
|
||||||
switch_core_session **new_session, switch_memory_pool *pool);
|
switch_core_session **new_session, switch_memory_pool *pool);
|
||||||
static switch_status channel_read_frame(switch_core_session *session, switch_frame **frame, int timeout,
|
static switch_status channel_read_frame(switch_core_session *session, switch_frame **frame, int timeout,
|
||||||
switch_io_flag flags, int stream_id);
|
switch_io_flag flags, int stream_id);
|
||||||
static switch_status channel_write_frame(switch_core_session *session, switch_frame *frame, int timeout,
|
static switch_status channel_write_frame(switch_core_session *session, switch_frame *frame, int timeout,
|
||||||
switch_io_flag flags, int stream_id);
|
switch_io_flag flags, int stream_id);
|
||||||
static switch_status channel_kill_channel(switch_core_session *session, int sig);
|
static switch_status channel_kill_channel(switch_core_session *session, int sig);
|
||||||
static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsession, ldl_signal_t signal, char *msg);
|
static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsession, ldl_signal_t signal, char *msg);
|
||||||
static ldl_status handle_response(ldl_handle_t *handle, char *id);
|
static ldl_status handle_response(ldl_handle_t *handle, char *id);
|
||||||
static switch_status load_config(void);
|
static switch_status load_config(void);
|
||||||
|
|
||||||
static void dl_logger(char *file, const char *func, int line, int level, char *fmt, ...)
|
static void dl_logger(char *file, const char *func, int line, int level, char *fmt, ...)
|
||||||
{
|
{
|
||||||
va_list ap;
|
va_list ap;
|
||||||
char data[1024];
|
char data[1024];
|
||||||
@ -330,6 +331,10 @@ static int do_candidates(struct private_object *tech_pvt, int force)
|
|||||||
switch_stun_random_string(tech_pvt->local_user, 16, NULL);
|
switch_stun_random_string(tech_pvt->local_user, 16, NULL);
|
||||||
switch_stun_random_string(tech_pvt->local_pass, 16, NULL);
|
switch_stun_random_string(tech_pvt->local_pass, 16, NULL);
|
||||||
|
|
||||||
|
if (switch_test_flag(tech_pvt, TFLAG_LANADDR)) {
|
||||||
|
advip = tech_pvt->profile->ip;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
cand[0].port = tech_pvt->local_port;
|
cand[0].port = tech_pvt->local_port;
|
||||||
cand[0].address = advip;
|
cand[0].address = advip;
|
||||||
@ -538,9 +543,9 @@ static void negotiate_thread_launch(switch_core_session *session)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
State methods they get called when the state changes to the specific state
|
State methods they get called when the state changes to the specific state
|
||||||
returning SWITCH_STATUS_SUCCESS tells the core to execute the standard state method next
|
returning SWITCH_STATUS_SUCCESS tells the core to execute the standard state method next
|
||||||
so if you fully implement the state you can return SWITCH_STATUS_FALSE to skip it.
|
so if you fully implement the state you can return SWITCH_STATUS_FALSE to skip it.
|
||||||
*/
|
*/
|
||||||
static switch_status channel_on_init(switch_core_session *session)
|
static switch_status channel_on_init(switch_core_session *session)
|
||||||
{
|
{
|
||||||
@ -1000,7 +1005,7 @@ static const switch_loadable_module_interface channel_module_interface = {
|
|||||||
|
|
||||||
|
|
||||||
/* Make sure when you have 2 sessions in the same scope that you pass the appropriate one to the routines
|
/* Make sure when you have 2 sessions in the same scope that you pass the appropriate one to the routines
|
||||||
that allocate memory or you will have 1 channel with memory allocated from another channel's pool!
|
that allocate memory or you will have 1 channel with memory allocated from another channel's pool!
|
||||||
*/
|
*/
|
||||||
static switch_status channel_outgoing_channel(switch_core_session *session, switch_caller_profile *outbound_profile,
|
static switch_status channel_outgoing_channel(switch_core_session *session, switch_caller_profile *outbound_profile,
|
||||||
switch_core_session **new_session, switch_memory_pool *pool)
|
switch_core_session **new_session, switch_memory_pool *pool)
|
||||||
@ -1277,7 +1282,6 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
|
|||||||
switch_core_session *session = NULL;
|
switch_core_session *session = NULL;
|
||||||
switch_channel *channel = NULL;
|
switch_channel *channel = NULL;
|
||||||
struct private_object *tech_pvt = NULL;
|
struct private_object *tech_pvt = NULL;
|
||||||
char *advip;
|
|
||||||
|
|
||||||
assert(dlsession != NULL);
|
assert(dlsession != NULL);
|
||||||
assert(handle != NULL);
|
assert(handle != NULL);
|
||||||
@ -1352,8 +1356,6 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
advip = profile->extip ? profile->extip : profile->ip;
|
|
||||||
|
|
||||||
switch(signal) {
|
switch(signal) {
|
||||||
case LDL_SIGNAL_NONE:
|
case LDL_SIGNAL_NONE:
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "ERROR\n");
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "ERROR\n");
|
||||||
@ -1443,9 +1445,11 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
|
|||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "%u candidates\n", len);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "%u candidates\n", len);
|
||||||
for(x = 0; x < len; x++) {
|
for(x = 0; x < len; x++) {
|
||||||
|
uint8_t lanaddr = strncasecmp(candidates[x].address, profile->lanaddr, strlen(profile->lanaddr)) ? 0 : 1;
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "candidates %s:%d\n", candidates[x].address, candidates[x].port);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "candidates %s:%d\n", candidates[x].address, candidates[x].port);
|
||||||
|
|
||||||
if (!strcasecmp(candidates[x].protocol, "udp") && (!strcasecmp(candidates[x].type, "local") || !strcasecmp(candidates[x].type, "stun")) &&
|
if (!strcasecmp(candidates[x].protocol, "udp") && (!strcasecmp(candidates[x].type, "local") || !strcasecmp(candidates[x].type, "stun")) &&
|
||||||
((profile->lanaddr && !strncasecmp(candidates[x].address, profile->lanaddr, strlen(profile->lanaddr))) ||
|
((profile->lanaddr && lanaddr) ||
|
||||||
(strncasecmp(candidates[x].address, "10.", 3) &&
|
(strncasecmp(candidates[x].address, "10.", 3) &&
|
||||||
strncasecmp(candidates[x].address, "192.168.", 8) &&
|
strncasecmp(candidates[x].address, "192.168.", 8) &&
|
||||||
strncasecmp(candidates[x].address, "127.", 4) &&
|
strncasecmp(candidates[x].address, "127.", 4) &&
|
||||||
@ -1464,6 +1468,9 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
|
|||||||
memset(payloads, 0, sizeof(payloads));
|
memset(payloads, 0, sizeof(payloads));
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Acceptable Candidate %s:%d\n", candidates[x].address, candidates[x].port);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Acceptable Candidate %s:%d\n", candidates[x].address, candidates[x].port);
|
||||||
|
if (lanaddr) {
|
||||||
|
switch_set_flag(tech_pvt, TFLAG_LANADDR);
|
||||||
|
}
|
||||||
|
|
||||||
if (!tech_pvt->num_codecs) {
|
if (!tech_pvt->num_codecs) {
|
||||||
get_codecs(tech_pvt);
|
get_codecs(tech_pvt);
|
||||||
|
@ -1818,7 +1818,6 @@ SWITCH_DECLARE(void) switch_core_session_run(switch_core_session *session)
|
|||||||
const switch_state_handler_table *driver_state_handler = NULL;
|
const switch_state_handler_table *driver_state_handler = NULL;
|
||||||
const switch_state_handler_table *application_state_handler = NULL;
|
const switch_state_handler_table *application_state_handler = NULL;
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Life of the channel. you have channel and pool in your session
|
Life of the channel. you have channel and pool in your session
|
||||||
everywhere you go you use the session to malloc with
|
everywhere you go you use the session to malloc with
|
||||||
|
Loading…
x
Reference in New Issue
Block a user