1 of many PRI/SIP gateway related updates

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@649 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2006-02-22 16:47:07 +00:00
parent c94e328db7
commit 9148e2b90e
2 changed files with 83 additions and 12 deletions

View File

@ -34,7 +34,6 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <fcntl.h> #include <fcntl.h>
static const char modname[] = "mod_bridgecall"; static const char modname[] = "mod_bridgecall";
struct audio_bridge_data { struct audio_bridge_data {

View File

@ -1,4 +1,4 @@
/* A/*
* FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application * FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
* Copyright (C) 2005/2006, Anthony Minessale II <anthmct@yahoo.com> * Copyright (C) 2005/2006, Anthony Minessale II <anthmct@yahoo.com>
* *
@ -29,17 +29,12 @@
* mod_wanpipe.c -- WANPIPE PRI Channel Module * mod_wanpipe.c -- WANPIPE PRI Channel Module
* *
*/ */
#include <switch.h> #include <switch.h>
#include <sys/types.h>
#include <sys/time.h>
#include <sys/queue.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <ctype.h>
#include <string.h>
#include <libsangoma.h> #include <libsangoma.h>
#include <sangoma_pri.h> #include <sangoma_pri.h>
#include <libteletone.h>
static const char modname[] = "mod_wanpipe"; static const char modname[] = "mod_wanpipe";
#define STRLEN 15 #define STRLEN 15
@ -110,6 +105,8 @@ struct private_object {
int callno; int callno;
int cause; int cause;
q931_call *call; q931_call *call;
teletone_generation_session_t tone_session;
switch_buffer *dtmf_buffer;
}; };
struct channel_map { struct channel_map {
@ -206,7 +203,6 @@ static void *pri_thread_run(switch_thread *thread, void *obj);
static int config_wanpipe(int reload); static int config_wanpipe(int reload);
/* /*
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
@ -253,6 +249,18 @@ static switch_status wanpipe_on_init(switch_core_session *session)
switch_core_session_set_read_codec(session, &tech_pvt->read_codec); switch_core_session_set_read_codec(session, &tech_pvt->read_codec);
switch_core_session_set_write_codec(session, &tech_pvt->write_codec); switch_core_session_set_write_codec(session, &tech_pvt->write_codec);
teletone_init_session(&tech_pvt->tone_session, 1024, NULL, NULL);
if (1 || globals.debug) {
tech_pvt->tone_session.debug = globals.debug;
tech_pvt->tone_session.debug_stream = stdout;
}
tech_pvt->tone_session.rate = rate;
tech_pvt->tone_session.duration = 150 * (tech_pvt->tone_session.rate / 1000);
tech_pvt->tone_session.wait = 50 * (tech_pvt->tone_session.rate / 1000);
/* Move Channel's State Machine to RING */ /* Move Channel's State Machine to RING */
switch_channel_set_state(channel, CS_RING); switch_channel_set_state(channel, CS_RING);
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
@ -314,6 +322,8 @@ static switch_status wanpipe_on_hangup(switch_core_session *session)
tech_pvt->hangup_event.hangup.call ? tech_pvt->hangup_event.hangup.call : tech_pvt->ring_event.ring.call); tech_pvt->hangup_event.hangup.call ? tech_pvt->hangup_event.hangup.call : tech_pvt->ring_event.ring.call);
*/ */
teletone_destroy_session(&tech_pvt->tone_session);
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
} }
@ -589,11 +599,73 @@ static switch_status wanpipe_write_frame(switch_core_session *session, switch_fr
return status; return status;
} }
static switch_status wanpipe_send_dtmf(switch_core_session *session, char *digits)
{
struct private_object *tech_pvt;
switch_channel *channel = NULL;
switch_status status = SWITCH_STATUS_SUCCESS;
int wrote = 0;
char *cur = NULL;
channel = switch_core_session_get_channel(session);
assert(channel != NULL);
tech_pvt = switch_core_session_get_private(session);
assert(tech_pvt != NULL);
if (!tech_pvt->dtmf_buffer) {
switch_console_printf(SWITCH_CHANNEL_CONSOLE, "Allocate DTMF Buffer....");
if (switch_buffer_create(switch_core_session_get_pool(session), &tech_pvt->dtmf_buffer, 960) != SWITCH_STATUS_SUCCESS) {
switch_console_printf(SWITCH_CHANNEL_CONSOLE, "FAILURE!\n");
return SWITCH_STATUS_FALSE;
} else {
switch_console_printf(SWITCH_CHANNEL_CONSOLE, "SUCCESS!\n");
}
}
for (cur = digits; *cur; cur++) {
if ((wrote = teletone_mux_tones(&tech_pvt->tone_session, &tech_pvt->tone_session.TONES[(int)*cur]))) {
switch_buffer_write(tech_pvt->dtmf_buffer, tech_pvt->tone_session.buffer, wrote * 2);
}
}
return status;
}
static switch_status wanpipe_receive_message(switch_core_session *session, switch_core_session_message *msg)
{
return SWITCH_STATUS_FALSE;
}
static switch_status wanpipe_kill_channel(switch_core_session *session, int sig)
{
struct private_object *tech_pvt;
switch_channel *channel = NULL;
channel = switch_core_session_get_channel(session);
assert(channel != NULL);
tech_pvt = switch_core_session_get_private(session);
assert(tech_pvt != NULL);
switch_clear_flag(tech_pvt, TFLAG_MEDIA);
return SWITCH_STATUS_SUCCESS;
}
static const switch_io_routines wanpipe_io_routines = { static const switch_io_routines wanpipe_io_routines = {
/*.outgoing_channel */ wanpipe_outgoing_channel, /*.outgoing_channel */ wanpipe_outgoing_channel,
/*.answer_channel */ wanpipe_answer_channel, /*.answer_channel */ wanpipe_answer_channel,
/*.read_frame */ wanpipe_read_frame, /*.read_frame */ wanpipe_read_frame,
/*.write_frame */ wanpipe_write_frame /*.write_frame */ wanpipe_write_frame,
/*.kill_channel */ wanpipe_kill_channel,
/*.waitfor_read */ NULL,
/*.waitfor_read */ NULL,
/*.send_dtmf*/ wanpipe_send_dtmf,
/*.receive_message*/ wanpipe_receive_message
}; };
static const switch_state_handler_table wanpipe_state_handlers = { static const switch_state_handler_table wanpipe_state_handlers = {