don't segfault when -nonat is used and nat_map reinit is called

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@16253 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Brian West 2010-01-12 00:40:43 +00:00
parent a4604e1af5
commit fe74b20563
5 changed files with 110 additions and 2 deletions

View File

@ -88,6 +88,10 @@ SWITCH_DECLARE(void) switch_nat_reinit(void);
\param sticky make the mapping permanent
*/
SWITCH_DECLARE(switch_status_t) switch_nat_add_mapping(switch_port_t port, switch_nat_ip_proto_t proto, switch_port_t *external_port, switch_bool_t sticky);
/*!
\brief Has the NAT subsystem been initialized
*/
SWITCH_DECLARE(switch_bool_t) switch_nat_is_initialized(void);
/*!
\brief Deletes a NAT mapping
\param proto Protocol

View File

@ -112,6 +112,11 @@ SWITCH_STANDARD_API(nat_map_function)
if (!cmd) {
goto error;
}
if (!switch_nat_is_initialized()) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "nat_map API called while NAT not initialized\n");
goto error;
}
mydata = strdup(cmd);
switch_assert(mydata);

View File

@ -2399,6 +2399,66 @@ SWIGEXPORT char * SWIGSTDCALL CSharp_switch_directories_storage_dir_get(void * j
}
SWIGEXPORT void SWIGSTDCALL CSharp_switch_directories_recordings_dir_set(void * jarg1, char * jarg2) {
switch_directories *arg1 = (switch_directories *) 0 ;
char *arg2 = (char *) 0 ;
arg1 = (switch_directories *)jarg1;
arg2 = (char *)jarg2;
{
if (arg1->recordings_dir) delete [] arg1->recordings_dir;
if (arg2) {
arg1->recordings_dir = (char *) (new char[strlen((const char *)arg2)+1]);
strcpy((char *)arg1->recordings_dir, (const char *)arg2);
} else {
arg1->recordings_dir = 0;
}
}
}
SWIGEXPORT char * SWIGSTDCALL CSharp_switch_directories_recordings_dir_get(void * jarg1) {
char * jresult ;
switch_directories *arg1 = (switch_directories *) 0 ;
char *result = 0 ;
arg1 = (switch_directories *)jarg1;
result = (char *) ((arg1)->recordings_dir);
jresult = SWIG_csharp_string_callback((const char *)result);
return jresult;
}
SWIGEXPORT void SWIGSTDCALL CSharp_switch_directories_sounds_dir_set(void * jarg1, char * jarg2) {
switch_directories *arg1 = (switch_directories *) 0 ;
char *arg2 = (char *) 0 ;
arg1 = (switch_directories *)jarg1;
arg2 = (char *)jarg2;
{
if (arg1->sounds_dir) delete [] arg1->sounds_dir;
if (arg2) {
arg1->sounds_dir = (char *) (new char[strlen((const char *)arg2)+1]);
strcpy((char *)arg1->sounds_dir, (const char *)arg2);
} else {
arg1->sounds_dir = 0;
}
}
}
SWIGEXPORT char * SWIGSTDCALL CSharp_switch_directories_sounds_dir_get(void * jarg1) {
char * jresult ;
switch_directories *arg1 = (switch_directories *) 0 ;
char *result = 0 ;
arg1 = (switch_directories *)jarg1;
result = (char *) ((arg1)->sounds_dir);
jresult = SWIG_csharp_string_callback((const char *)result);
return jresult;
}
SWIGEXPORT void * SWIGSTDCALL CSharp_new_switch_directories() {
void * jresult ;
switch_directories *result = 0 ;

View File

@ -5490,6 +5490,18 @@ class freeswitchPINVOKE {
[DllImport("mod_managed", EntryPoint="CSharp_switch_directories_storage_dir_get")]
public static extern string switch_directories_storage_dir_get(HandleRef jarg1);
[DllImport("mod_managed", EntryPoint="CSharp_switch_directories_recordings_dir_set")]
public static extern void switch_directories_recordings_dir_set(HandleRef jarg1, string jarg2);
[DllImport("mod_managed", EntryPoint="CSharp_switch_directories_recordings_dir_get")]
public static extern string switch_directories_recordings_dir_get(HandleRef jarg1);
[DllImport("mod_managed", EntryPoint="CSharp_switch_directories_sounds_dir_set")]
public static extern void switch_directories_sounds_dir_set(HandleRef jarg1, string jarg2);
[DllImport("mod_managed", EntryPoint="CSharp_switch_directories_sounds_dir_get")]
public static extern string switch_directories_sounds_dir_get(HandleRef jarg1);
[DllImport("mod_managed", EntryPoint="CSharp_new_switch_directories")]
public static extern IntPtr new_switch_directories();
@ -21594,6 +21606,26 @@ public class switch_directories : IDisposable {
}
}
public string recordings_dir {
set {
freeswitchPINVOKE.switch_directories_recordings_dir_set(swigCPtr, value);
}
get {
string ret = freeswitchPINVOKE.switch_directories_recordings_dir_get(swigCPtr);
return ret;
}
}
public string sounds_dir {
set {
freeswitchPINVOKE.switch_directories_sounds_dir_set(swigCPtr, value);
}
get {
string ret = freeswitchPINVOKE.switch_directories_sounds_dir_get(swigCPtr);
return ret;
}
}
public switch_directories() : this(freeswitchPINVOKE.new_switch_directories(), true) {
}
@ -22473,6 +22505,7 @@ public enum switch_event_types_t {
SWITCH_EVENT_RECORD_STOP,
SWITCH_EVENT_CALL_UPDATE,
SWITCH_EVENT_FAILURE,
SWITCH_EVENT_SOCKET_DATA,
SWITCH_EVENT_ALL
}
@ -26256,7 +26289,8 @@ public enum switch_session_ctl_t {
SCSC_CANCEL_SHUTDOWN,
SCSC_SEND_SIGHUP,
SCSC_DEBUG_LEVEL,
SCSC_FLUSH_DB_HANDLES
SCSC_FLUSH_DB_HANDLES,
SCSC_SHUTDOWN_NOW
}
}

View File

@ -63,6 +63,7 @@ typedef struct {
static nat_globals_perm_t nat_globals_perm;
static switch_bool_t first_init = SWITCH_TRUE;
static switch_bool_t initialized = SWITCH_FALSE;
static switch_status_t get_upnp_pubaddr(char *pub_addr)
{
@ -414,6 +415,7 @@ SWITCH_DECLARE(void) switch_nat_init(switch_memory_pool_t *pool)
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "No PMP or UPnP NAT devices detected!\n");
}
first_init = SWITCH_FALSE;
initialized = SWITCH_TRUE;
}
static switch_status_t switch_nat_add_mapping_pmp(switch_port_t port, switch_nat_ip_proto_t proto, switch_port_t *external_port)
@ -630,7 +632,6 @@ SWITCH_DECLARE(void) switch_nat_republish(void)
if (!(natxml = switch_xml_parse_str_dup(stream.data))) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Unable to parse XML: %s\n", (char *) stream.data);
switch_safe_free(stream.data);
return;
}
/* iterate the xml and publish the mappings */
@ -677,6 +678,10 @@ SWITCH_DECLARE(char *) switch_nat_status(void)
return stream.data; /* caller frees */
}
SWITCH_DECLARE(switch_bool_t) switch_nat_is_initialized(void)
{
return initialized;
}
SWITCH_DECLARE(void) switch_nat_shutdown(void)
{