Please remove fork=no from the configuration file. This is useful only
for debugging and should not be used normally. There is no guarantee
that all the modules will work in fork=no mode.
Jan.
On 25-10-2005 16:05, Hilco de Lathouder wrote:
I've compiled SER 0.94, including support for persistent auth (module
mysql). It seemed to work pretty well, but after a while i keep
getting segmentation faults when restarting ser. Only a complete
rebuild of the database with the ser_mysql script seems to fix things
for a while. I've inluded my ser.cfg and the output from 'ser -E
2>serlog' . The problem only seems to happen when i use the auth_db
module.
++++++++++++++ SER Debug output below ++++++++++++++++++
0(4067) loading module /usr/local/lib/ser/modules/mysql.so
0(4067) loading module /usr/local/lib/ser/modules/sl.so
0(4067) loading module /usr/local/lib/ser/modules/tm.so
0(4067) loading module /usr/local/lib/ser/modules/rr.so
0(4067) loading module /usr/local/lib/ser/modules/maxfwd.so
0(4067) loading module /usr/local/lib/ser/modules/usrloc.so
0(4067) loading module /usr/local/lib/ser/modules/registrar.so
0(4067) loading module /usr/local/lib/ser/modules/exec.so
0(4067) loading module /usr/local/lib/ser/modules/uri.so
0(4067) loading module /usr/local/lib/ser/modules/acc.so
0(4067) loading module /usr/local/lib/ser/modules/textops.so
0(4067) loading module /usr/local/lib/ser/modules/auth.so
0(4067) loading module /usr/local/lib/ser/modules/auth_db.so
0(4067) set_mod_param_regex: usrloc matches module usrloc
0(4067) set_mod_param_regex: found <db_mode> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(4067) set_mod_param_regex: auth_db matches module auth_db
0(4067) set_mod_param_regex: found <calculate_ha1> in module auth_db
[/usr/local/lib/ser/modules/auth_db.so]
0(4067) set_mod_param_regex: auth_db matches module auth_db
0(4067) set_mod_param_regex: found <password_column> in module
auth_db [/usr/local/lib/ser/modules/auth_db.so]
0(4067) set_mod_param_regex: rr matches module rr
0(4067) set_mod_param_regex: found <enable_full_lr> in module rr
[/usr/local/lib/ser/modules/rr.so]
0(4067) set_mod_param_regex: rr matches module rr
0(4067) set_mod_param_regex: found <enable_double_rr> in module rr
[/usr/local/lib/ser/modules/rr.so]
0(4067) set_mod_param_regex: rr matches module rr
0(4067) set_mod_param_regex: found <add_username> in module rr
[/usr/local/lib/ser/modules/rr.so]
0(4067) find_export: found <mf_process_maxfwd_header> in module
maxfwd [/usr/local/lib/ser/modules/maxfwd.so]
0(4067) find_export: found <sl_send_reply> in module sl_module
[/usr/local/lib/ser/modules/sl.so]
0(4067) find_export: found <sl_send_reply> in module sl_module
[/usr/local/lib/ser/modules/sl.so]
0(4067) find_export: found <record_route> in module rr
[/usr/local/lib/ser/modules/rr.so]
0(4067) find_export: found <loose_route> in module rr
[/usr/local/lib/ser/modules/rr.so]
0(4067) find_export: found <append_hf> in module textops
[/usr/local/lib/ser/modules/textops.so]
0(4067) find_export: found <append_hf> in module textops
[/usr/local/lib/ser/modules/textops.so]
0(4067) find_export: found <www_authorize> in module auth_db
[/usr/local/lib/ser/modules/auth_db.so]
0(4067) find_export: found <www_challenge> in module auth
[/usr/local/lib/ser/modules/auth.so]
0(4067) find_export: found <save> in module registrar
[/usr/local/lib/ser/modules/registrar.so]
0(4067) find_export: found <lookup> in module registrar
[/usr/local/lib/ser/modules/registrar.so]
0(4067) find_export: found <append_hf> in module textops
[/usr/local/lib/ser/modules/textops.so]
0(4067) find_export: found <lookup> in module registrar
[/usr/local/lib/ser/modules/registrar.so]
0(4067) find_export: found <sl_send_reply> in module sl_module
[/usr/local/lib/ser/modules/sl.so]
0(4067) find_export: found <append_hf> in module textops
[/usr/local/lib/ser/modules/textops.so]
0(4067) find_export: found <t_relay> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(4067) find_export: found <sl_reply_error> in module sl_module
[/usr/local/lib/ser/modules/sl.so]
0(4067) routing table 0:
0(4067) if ( 0(4067) NOT( 0(4067) external_module_call( 0(4067)
f_ptr<0xb7f32db0> 0(4067) , "10" 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7f32db0> 0(4067) , "10"
0(4067)
); 0(4067) ) 0(4067) ) { 0(4067) external_module_call( 0(4067)
f_ptr<0xb7de7790> 0(4067) , "483" 0(4067) , "Too Many Hops"
0(4067)
); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067)
}; 0(4067) if ( 0(4067) UNKNOWN 0(4067) <UNKNOWN> 0(4067) 2048
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7de7790>
0(4067) , "513" 0(4067) , "Message too big" 0(4067) ); 0(4067)
drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7f384f0> 0(4067) ); 0(4067) if
( 0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: rr-enforced
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) NOT( 0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) )
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: outbound
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) ) { 0(4067) if (
0(4067) method 0(4067) == 0(4067) "REGISTER" 0(4067) ) { 0(4067) if (
0(4067) NOT( 0(4067) external_module_call( 0(4067) f_ptr<0xb7d67d80>
0(4067) , "newbridges.nl" 0(4067) , "subscriber" 0(4067) );
0(4067)
external_module_call( 0(4067) f_ptr<0xb7d67d80> 0(4067) ,
"newbridges.nl" 0(4067) , "subscriber" 0(4067) ); 0(4067) )
0(4067)
) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d6eb10> 0(4067) ,
"newbridges.nl" 0(4067) , "0" 0(4067) ); 0(4067) drop( 0(4067)
type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d8a800> 0(4067) , "location"
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) external_module_call( 0(4067) f_ptr<0xb7d87d60>
0(4067) , "aliases" 0(4067) ); 0(4067) if ( 0(4067) NOT( 0(4067) uri
0(4067) == 0(4067) _myself_ 0(4067) ) 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
outbound alias
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) "^[1]si[2]"^sip:[5-7][0-9]{2,3}@.*"
0(4067) ) { 0(4067) log( 0(4067) 1 0(4067) , "LOG: PBX call,
contacting gateway...
" 0(4067) ); 0(4067) route( 0(4067) 2 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) [3]"sip:[0-9]{5,20}@.*" 0(4067) ) {
0(4067) if ( 0(4067) method 0(4067) == 0(4067) "INVITE" 0(4067) ) {
0(4067) log( 0(4067) 1 0(4067) , "LOG: PSTN call, contacting
gateway...
" 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) route( 0(4067) 3
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) if ( 0(4067) NOT( 0(4067) external_module_call(
0(4067) f_ptr<0xb7d87d60> 0(4067) , "location" 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d87d60> 0(4067) , "location"
0(4067) ); 0(4067) ) 0(4067) ) { 0(4067) external_module_call(
0(4067) f_ptr<0xb7de7790> 0(4067) , "404" 0(4067) , "User Not
Found /
Offline" 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
} else { 0(4067) }; 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
usrloc applied
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) if (
0(4067) UNKNOWN 0(4067) <UNKNOWN> 0(4067) 2048 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7de7790> 0(4067) , "513"
0(4067) , "Message too big" 0(4067) ); 0(4067) drop( 0(4067) type<0>
0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7f384f0> 0(4067) ); 0(4067) if
( 0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: rr-enforced
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) NOT( 0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) )
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: outbound
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) ) { 0(4067) if (
0(4067) method 0(4067) == 0(4067) "REGISTER" 0(4067) ) { 0(4067) if (
0(4067) NOT( 0(4067) external_module_call( 0(4067) f_ptr<0xb7d67d80>
0(4067) , "newbridges.nl" 0(4067) , "subscriber" 0(4067) );
0(4067)
external_module_call( 0(4067) f_ptr<0xb7d67d80> 0(4067) ,
"newbridges.nl" 0(4067) , "subscriber" 0(4067) ); 0(4067) )
0(4067)
) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d6eb10> 0(4067) ,
"newbridges.nl" 0(4067) , "0" 0(4067) ); 0(4067) drop( 0(4067)
type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d8a800> 0(4067) , "location"
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) external_module_call( 0(4067) f_ptr<0xb7d87d60>
0(4067) , "aliases" 0(4067) ); 0(4067) if ( 0(4067) NOT( 0(4067) uri
0(4067) == 0(4067) _myself_ 0(4067) ) 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
outbound alias
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) "^[4]si[5]"^sip:[5-7][0-9]{2,3}@.*"
0(4067) ) { 0(4067) log( 0(4067) 1 0(4067) , "LOG: PBX call,
contacting gateway...
" 0(4067) ); 0(4067) route( 0(4067) 2 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) [6]"sip:[0-9]{5,20}@.*" 0(4067) ) {
0(4067) if ( 0(4067) method 0(4067) == 0(4067) "INVITE" 0(4067) ) {
0(4067) log( 0(4067) 1 0(4067) , "LOG: PSTN call, contacting
gateway...
" 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) route( 0(4067) 3
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) if ( 0(4067) NOT( 0(4067) external_module_call(
0(4067) f_ptr<0xb7d87d60> 0(4067) , "location" 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d87d60> 0(4067) , "location"
0(4067) ); 0(4067) ) 0(4067) ) { 0(4067) external_module_call(
0(4067) f_ptr<0xb7de7790> 0(4067) , "404" 0(4067) , "User Not
Found /
Offline" 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
} else { 0(4067) }; 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
usrloc applied
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7f384f0> 0(4067) ); 0(4067) if
( 0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: rr-enforced
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) NOT( 0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) )
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: outbound
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) ) { 0(4067) if (
0(4067) method 0(4067) == 0(4067) "REGISTER" 0(4067) ) { 0(4067) if (
0(4067) NOT( 0(4067) external_module_call( 0(4067) f_ptr<0xb7d67d80>
0(4067) , "newbridges.nl" 0(4067) , "subscriber" 0(4067) );
0(4067)
external_module_call( 0(4067) f_ptr<0xb7d67d80> 0(4067) ,
"newbridges.nl" 0(4067) , "subscriber" 0(4067) ); 0(4067) )
0(4067)
) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d6eb10> 0(4067) ,
"newbridges.nl" 0(4067) , "0" 0(4067) ); 0(4067) drop( 0(4067)
type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d8a800> 0(4067) , "location"
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) external_module_call( 0(4067) f_ptr<0xb7d87d60>
0(4067) , "aliases" 0(4067) ); 0(4067) if ( 0(4067) NOT( 0(4067) uri
0(4067) == 0(4067) _myself_ 0(4067) ) 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
outbound alias
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) "^[7]si[8]"^sip:[5-7][0-9]{2,3}@.*"
0(4067) ) { 0(4067) log( 0(4067) 1 0(4067) , "LOG: PBX call,
contacting gateway...
" 0(4067) ); 0(4067) route( 0(4067) 2 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) [9]"sip:[0-9]{5,20}@.*" 0(4067) ) {
0(4067) if ( 0(4067) method 0(4067) == 0(4067) "INVITE" 0(4067) ) {
0(4067) log( 0(4067) 1 0(4067) , "LOG: PSTN call, contacting
gateway...
" 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) route( 0(4067) 3
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) if ( 0(4067) NOT( 0(4067) external_module_call(
0(4067) f_ptr<0xb7d87d60> 0(4067) , "location" 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d87d60> 0(4067) , "location"
0(4067) ); 0(4067) ) 0(4067) ) { 0(4067) external_module_call(
0(4067) f_ptr<0xb7de7790> 0(4067) , "404" 0(4067) , "User Not
Found /
Offline" 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
} else { 0(4067) }; 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
usrloc applied
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) if (
0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) external_module_call( 0(4067) f_ptr<0xb7f36c30> 0(4067) );
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: rr-enforced
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) NOT( 0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) )
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: outbound
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) ) { 0(4067) if (
0(4067) method 0(4067) == 0(4067) "REGISTER" 0(4067) ) { 0(4067) if (
0(4067) NOT( 0(4067) external_module_call( 0(4067) f_ptr<0xb7d67d80>
0(4067) , "newbridges.nl" 0(4067) , "subscriber" 0(4067) );
0(4067)
external_module_call( 0(4067) f_ptr<0xb7d67d80> 0(4067) ,
"newbridges.nl" 0(4067) , "subscriber" 0(4067) ); 0(4067) )
0(4067)
) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d6eb10> 0(4067) ,
"newbridges.nl" 0(4067) , "0" 0(4067) ); 0(4067) drop( 0(4067)
type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d8a800> 0(4067) , "location"
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) external_module_call( 0(4067) f_ptr<0xb7d87d60>
0(4067) , "aliases" 0(4067) ); 0(4067) if ( 0(4067) NOT( 0(4067) uri
0(4067) == 0(4067) _myself_ 0(4067) ) 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
outbound alias
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) "^[10]si[11]"^sip:[5-7][0-9]{2,3}@.*"
0(4067) ) { 0(4067) log( 0(4067) 1 0(4067) , "LOG: PBX call,
contacting gateway...
" 0(4067) ); 0(4067) route( 0(4067) 2 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) [12]"sip:[0-9]{5,20}@.*" 0(4067) ) {
0(4067) if ( 0(4067) method 0(4067) == 0(4067) "INVITE" 0(4067) ) {
0(4067) log( 0(4067) 1 0(4067) , "LOG: PSTN call, contacting
gateway...
" 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) route( 0(4067) 3
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) if ( 0(4067) NOT( 0(4067) external_module_call(
0(4067) f_ptr<0xb7d87d60> 0(4067) , "location" 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d87d60> 0(4067) , "location"
0(4067) ); 0(4067) ) 0(4067) ) { 0(4067) external_module_call(
0(4067) f_ptr<0xb7de7790> 0(4067) , "404" 0(4067) , "User Not
Found /
Offline" 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
} else { 0(4067) }; 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
usrloc applied
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) if (
0(4067) NOT( 0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) )
0(4067) ) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d75650>
0(4067) , "P-hint: outbound
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) ) { 0(4067) if (
0(4067) method 0(4067) == 0(4067) "REGISTER" 0(4067) ) { 0(4067) if (
0(4067) NOT( 0(4067) external_module_call( 0(4067) f_ptr<0xb7d67d80>
0(4067) , "newbridges.nl" 0(4067) , "subscriber" 0(4067) );
0(4067)
external_module_call( 0(4067) f_ptr<0xb7d67d80> 0(4067) ,
"newbridges.nl" 0(4067) , "subscriber" 0(4067) ); 0(4067) )
0(4067)
) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d6eb10> 0(4067) ,
"newbridges.nl" 0(4067) , "0" 0(4067) ); 0(4067) drop( 0(4067)
type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d8a800> 0(4067) , "location"
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) external_module_call( 0(4067) f_ptr<0xb7d87d60>
0(4067) , "aliases" 0(4067) ); 0(4067) if ( 0(4067) NOT( 0(4067) uri
0(4067) == 0(4067) _myself_ 0(4067) ) 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
outbound alias
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) "^[13]si[14]"^sip:[5-7][0-9]{2,3}@.*"
0(4067) ) { 0(4067) log( 0(4067) 1 0(4067) , "LOG: PBX call,
contacting gateway...
" 0(4067) ); 0(4067) route( 0(4067) 2 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) [15]"sip:[0-9]{5,20}@.*" 0(4067) ) {
0(4067) if ( 0(4067) method 0(4067) == 0(4067) "INVITE" 0(4067) ) {
0(4067) log( 0(4067) 1 0(4067) , "LOG: PSTN call, contacting
gateway...
" 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) route( 0(4067) 3
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) if ( 0(4067) NOT( 0(4067) external_module_call(
0(4067) f_ptr<0xb7d87d60> 0(4067) , "location" 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d87d60> 0(4067) , "location"
0(4067) ); 0(4067) ) 0(4067) ) { 0(4067) external_module_call(
0(4067) f_ptr<0xb7de7790> 0(4067) , "404" 0(4067) , "User Not
Found /
Offline" 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
} else { 0(4067) }; 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
usrloc applied
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) if (
0(4067) uri 0(4067) == 0(4067) _myself_ 0(4067) ) { 0(4067) if (
0(4067) method 0(4067) == 0(4067) "REGISTER" 0(4067) ) { 0(4067) if (
0(4067) NOT( 0(4067) external_module_call( 0(4067) f_ptr<0xb7d67d80>
0(4067) , "newbridges.nl" 0(4067) , "subscriber" 0(4067) );
0(4067)
external_module_call( 0(4067) f_ptr<0xb7d67d80> 0(4067) ,
"newbridges.nl" 0(4067) , "subscriber" 0(4067) ); 0(4067) )
0(4067)
) { 0(4067) external_module_call( 0(4067) f_ptr<0xb7d6eb10> 0(4067) ,
"newbridges.nl" 0(4067) , "0" 0(4067) ); 0(4067) drop( 0(4067)
type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d8a800> 0(4067) , "location"
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) external_module_call( 0(4067) f_ptr<0xb7d87d60>
0(4067) , "aliases" 0(4067) ); 0(4067) if ( 0(4067) NOT( 0(4067) uri
0(4067) == 0(4067) _myself_ 0(4067) ) 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
outbound alias
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) "^[16]si[17]"^sip:[5-7][0-9]{2,3}@.*"
0(4067) ) { 0(4067) log( 0(4067) 1 0(4067) , "LOG: PBX call,
contacting gateway...
" 0(4067) ); 0(4067) route( 0(4067) 2 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) if (
0(4067) uri 0(4067) =~ 0(4067) [18]"sip:[0-9]{5,20}@.*" 0(4067) ) {
0(4067) if ( 0(4067) method 0(4067) == 0(4067) "INVITE" 0(4067) ) {
0(4067) log( 0(4067) 1 0(4067) , "LOG: PSTN call, contacting
gateway...
" 0(4067) ); 0(4067) } else { 0(4067) }; 0(4067) route( 0(4067) 3
0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067) } else {
0(4067) }; 0(4067) if ( 0(4067) NOT( 0(4067) external_module_call(
0(4067) f_ptr<0xb7d87d60> 0(4067) , "location" 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d87d60> 0(4067) , "location"
0(4067) ); 0(4067) ) 0(4067) ) { 0(4067) external_module_call(
0(4067) f_ptr<0xb7de7790> 0(4067) , "404" 0(4067) , "User Not
Found /
Offline" 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
} else { 0(4067) }; 0(4067) } else { 0(4067) }; 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
usrloc applied
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067)
external_module_call( 0(4067) f_ptr<0xb7d75650> 0(4067) , "P-hint:
usrloc applied
" 0(4067) ); 0(4067) route( 0(4067) 1 0(4067) ); 0(4067) route(
0(4067) 1 0(4067) ); 0(4067)
0(4067) routing table 1:
0(4067) if ( 0(4067) NOT( 0(4067) external_module_call( 0(4067)
f_ptr<0xb7dbc1e0> 0(4067) ); 0(4067) external_module_call( 0(4067)
f_ptr<0xb7dbc1e0> 0(4067) ); 0(4067) ) 0(4067) ) { 0(4067)
external_module_call( 0(4067) f_ptr<0xb7de77d0> 0(4067) ); 0(4067) }
else { 0(4067) }; 0(4067)
0(4067) routing table 2:
0(4067) sethostport( 0(4067) "192.168.1.244:5060" 0(4067) ); 0(4067)
forward( 0(4067) type<11> 0(4067) , type<12> 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) forward( 0(4067) type<11> 0(4067)
, type<12> 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) );
0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
0(4067) routing table 3:
0(4067) sethostport( 0(4067) "192.168.1.244:5060" 0(4067) ); 0(4067)
forward( 0(4067) type<11> 0(4067) , type<12> 0(4067) ); 0(4067) drop(
0(4067) type<0> 0(4067) ); 0(4067) forward( 0(4067) type<11> 0(4067)
, type<12> 0(4067) ); 0(4067) drop( 0(4067) type<0> 0(4067) );
0(4067) drop( 0(4067) type<0> 0(4067) ); 0(4067)
WARNING: no fork mode and more than one listen address found(will use
only the the first one)
0(4067) shm_mem_init: success
0(0) core dump limits set to 4294967295
0(0) DEBUG: init_mod: sl_module
stateless - initializing
0(0) DEBUG: register_fifo_cmd: new command (sl_stats) registered
0(0) unixsock_register_cmd: New command (sl_stats) registered
0(0) DEBUG: MD5 calculated: b27e1a1d33761e85846fc98f5f3a7e58
0(0) DEBUG: init_mod: tm
0(0) TM - (size of cell=2776, sip_msg=760) initializing...
0(0) Call-ID initialization: '7bee7c3b'
0(0) DEBUG: register_fifo_cmd: new command (t_uac_dlg) registered
0(0) DEBUG: register_fifo_cmd: new command (t_uac_cancel) registered
0(0) DEBUG: register_fifo_cmd: new command (t_hash) registered
0(0) DEBUG: register_fifo_cmd: new command (t_reply) registered
0(0) unixsock_register_cmd: New command (t_uac_dlg) registered
0(0) unixsock_register_cmd: New command (t_uac_cancel) registered
0(0) unixsock_register_cmd: New command (t_hash) registered
0(0) unixsock_register_cmd: New command (t_reply) registered
0(0) DEBUG: lock_initialize: lock initialization started
0(0) DEBUG: register_fifo_cmd: new command (t_stats) registered
0(0) unixsock_register_cmd: New command (t_stats) registered
0(0) DEBUG: MD5 calculated: 533cb9e91f4b999cf76861cbb9ed54ed
0(0) DEBUG: MD5 calculated: a6a1c5f60faecf035a1ae5b6e96e979a
0(0) DEBUG: init_mod: rr
0(0) rr - initializing
0(0) DEBUG: init_mod: maxfwd
0(0) Maxfwd module- initializing
0(0) DEBUG: init_mod: usrloc
0(0) usrloc - initializing
0(0) DEBUG: register_fifo_cmd: new command (ul_stats) registered
0(0) DEBUG: register_fifo_cmd: new command (ul_rm) registered
0(0) DEBUG: register_fifo_cmd: new command (ul_rm_contact) registered
0(0) DEBUG: register_fifo_cmd: new command (ul_dump) registered
0(0) DEBUG: register_fifo_cmd: new command (ul_flush) registered
0(0) DEBUG: register_fifo_cmd: new command (ul_add) registered
0(0) DEBUG: register_fifo_cmd: new command (ul_show_contact)
registered
0(0) unixsock_register_cmd: New command (ul_stats) registered
0(0) unixsock_register_cmd: New command (ul_rm) registered
0(0) unixsock_register_cmd: New command (ul_rm_contact) registered
0(0) unixsock_register_cmd: New command (ul_dump) registered
0(0) unixsock_register_cmd: New command (ul_flush) registered
0(0) unixsock_register_cmd: New command (ul_add) registered
0(0) unixsock_register_cmd: New command (ul_show_contact) registered
0(0) find_mod_export: found <db_use_table> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_init> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_close> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_query> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_raw_query> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_free_result> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_insert> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_delete> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_update> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) DEBUG: init_mod: registrar
0(0) registrar - initializing
0(0) find_export: found <sl_send_reply> in module sl_module
[/usr/local/lib/ser/modules/sl.so]
0(0) find_export: found <ul_bind_usrloc> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_register_udomain> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_get_all_ucontacts> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_insert_urecord> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_delete_urecord> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_get_urecord> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_lock_udomain> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_unlock_udomain> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_release_urecord> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_insert_ucontact> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_delete_ucontact> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_get_ucontact> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_update_ucontact> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_register_watcher> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_unregister_watcher> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) find_export: found <ul_register_ulcb> in module usrloc
[/usr/local/lib/ser/modules/usrloc.so]
0(0) DEBUG: init_mod: exec
exec - initializing
0(0) DEBUG: init_mod: acc
acc - initializing
0(0) find_export: found <load_tm> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <register_tmcb> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_newtran> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_relay_to_tcp> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_relay_to_udp> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_relay> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_reply> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_reply_with_body> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_is_local> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_get_trans_ident> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_lookup_ident> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_add_blind> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_forward_nonack> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_request_within> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_request_outside> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_request> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <new_dlg_uac> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <dlg_response_uac> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <new_dlg_uas> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <dlg_request_uas> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <free_dlg> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <print_dlg> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) find_export: found <t_gett> in module tm
[/usr/local/lib/ser/modules/tm.so]
0(0) DEBUG: init_mod: textops
textops - initializing
0(0) DEBUG: init_mod: auth
0(0) auth module - initializing
0(0) find_export: found <sl_send_reply> in module sl_module
[/usr/local/lib/ser/modules/sl.so]
0(0) DEBUG: init_mod: auth_db
0(0) auth_db module - initializing
0(0) find_mod_export: found <db_use_table> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_init> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_close> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_query> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_raw_query> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_free_result> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_insert> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_delete> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_mod_export: found <db_update> in module mysql
[/usr/local/lib/ser/modules/mysql.so]
0(0) find_export: found <pre_auth> in module auth
[/usr/local/lib/ser/modules/auth.so]
0(0) find_export: found <post_auth> in module auth
[/usr/local/lib/ser/modules/auth.so]
0(0) find_export: found <sl_send_reply> in module sl_module
[/usr/local/lib/ser/modules/sl.so]
0(0) fixing /usr/local/lib/ser/modules/maxfwd.so
mf_process_maxfwd_header
0(0) fixing /usr/local/lib/ser/modules/sl.so sl_send_reply
0(0) fixing /usr/local/lib/ser/modules/sl.so sl_send_reply
0(0) fixing /usr/local/lib/ser/modules/rr.so record_route
0(0) fixing /usr/local/lib/ser/modules/rr.so loose_route
0(0) fixing /usr/local/lib/ser/modules/textops.so append_hf
0(0) fixing /usr/local/lib/ser/modules/textops.so append_hf
0(0) fixing /usr/local/lib/ser/modules/auth_db.so www_authorize
0(0) get_connection(): Connection not found in the pool
0(0) release_connection(): Removing connection from the pool
0(0) fixing /usr/local/lib/ser/modules/auth.so www_challenge
0(0) fixing /usr/local/lib/ser/modules/registrar.so save
0(0) get_connection(): Connection not found in the pool
++++++++++ Config file below +++++++++++++++++++
# ----------- global configuration parameters ------
# Debugging
#
# Max level = 9, or ser -ddddddddd
# Don't use forking while debugging
debug=9
fork=no
log_stderror=yes # (cmd line: -E)
# -- Debug mode --
/*
fork=no
debug=6
log_stderror=yes
*/
check_via=no # (cmd. line: -v)
dns=no # (cmd. line: -r)
rev_dns=no # (cmd. line: -R)
port=5060
children=4
fifo="/tmp/ser_fifo"
alias=newbridges.nl
alias=192.168.1.247
# ------------------ module loading ----------------------------------
# Uncomment this if you want to use SQL database
loadmodule "/usr/local/lib/ser/modules/mysql.so"
loadmodule "/usr/local/lib/ser/modules/sl.so"
loadmodule "/usr/local/lib/ser/modules/tm.so"
loadmodule "/usr/local/lib/ser/modules/rr.so"
loadmodule "/usr/local/lib/ser/modules/maxfwd.so"
loadmodule "/usr/local/lib/ser/modules/usrloc.so"
loadmodule "/usr/local/lib/ser/modules/registrar.so"
# added 30-06-05
loadmodule "/usr/local/lib/ser/modules/exec.so"
loadmodule "/usr/local/lib/ser/modules/uri.so"
loadmodule "/usr/local/lib/ser/modules/acc.so"
loadmodule "/usr/local/lib/ser/modules/textops.so"
# Digest authentication
# mysql.so must be loaded !
loadmodule "/usr/local/lib/ser/modules/auth.so"
loadmodule "/usr/local/lib/ser/modules/auth_db.so"
# ----------------- setting module-specific parameters ---------------
# -- usrloc params --
# Use this for non-persistent data storage
#modparam("usrloc", "db_mode", 0)
# use this for persistent storage (and comment the previous line)
modparam("usrloc", "db_mode", 2)
# -- auth params --
modparam("auth_db", "calculate_ha1", yes)
# If you set "calculate_ha1" parameter to yes (which true in this
config),
# uncomment also the following parameter)
modparam("auth_db", "password_column", "password")
# -- rr params --
# add value to ;lr param to make some broken UAs happy
modparam("rr", "enable_full_lr", 1)
modparam("rr", "enable_double_rr", 1)
modparam("rr", "add_username", 1)
# ------------------------- request routing logic -------------------
# main routing logic
#
# This defines the handling of incorrect and Register messages,
# and sends message to other routes :
#
# 1) (main route)
# 2) PBX
# 3) PSTN / Gateway traffic
route{
# initial sanity checks -- messages with
# max_forwards==0, or excessively long requests
if (!mf_process_maxfwd_header("10")) {
sl_send_reply("483","Too Many Hops");
break;
};
if (msg:len >= 2048 ) {
sl_send_reply("513", "Message too big");
break;
};
# we record-route all messages -- to make sure that
# subsequent messages will go through our proxy; that's
# particularly good if upstream and downstream entities
# use different transport protocol
record_route();
# subsequent messages withing a dialog should take the
# path determined by record-routing
# ACKS follow this path
if (loose_route()) {
# mark routing logic in request
append_hf("P-hint: rr-enforced\r\n");
route(1);
break;
};
if (!uri==myself) {
# mark routing logic in request
append_hf("P-hint: outbound\r\n");
route(1);
break;
};
# if the request is for other domain use UsrLoc
# (in case, it does not work, use the following command
# with proper names and addresses in it)
if (uri==myself) {
if (method=="REGISTER") {
# Uncomment this if you want to use digest authentication
if (!www_authorize("newbridges.nl", "subscriber")) {
www_challenge("newbridges.nl", "0");
break;
};
save("location");
break;
};
lookup("aliases");
if (!uri==myself) {
append_hf("P-hint: outbound alias\r\n");
route(1);
break;
};
# This part handles numbers (5xx,6xx,7xx) and (5xxx,6xxx,7xxx)
# which are internal numbers for the PABX
#
if (uri=~"^[19]si[20]"^sip:[5-7][0-9]{2,3}@.*") {
log(1, "LOG: PBX call, contacting gateway...\n");
route(2);
break;
};
#
# Gateway traffic directly to PSTN
#
# The assumption is that other all
# numeric usernames between 5 and 20 digits are really pstn
numbers
# and so they are routed to the gateway
if (uri=~[21]"sip:[0-9]{5,20}@.*") {
if (method=="INVITE"){
log(1, "LOG: PSTN call, contacting gateway...\n");
};
route(3);
break;
};
# native SIP destinations are handled using our USRLOC DB
if (!lookup("location")) {
sl_send_reply("404", "User Not Found / Offline");
break;
};
};
append_hf("P-hint: usrloc applied\r\n");
route(1);
}
# main route
route[1]
{
# send it out now; use stateful forwarding as it works reliably
# even for UDP2TCP
if (!t_relay()) {
sl_reply_error();
};
}
# PBX/gateway traffic
# the '01' prefix specifies which port the gateway should use
route[2]
{
rewritehostport("192.168.1.244:5060");
forward(uri:host, uri:port);
break;
} /* end of route 2 - PBX traffic*/
# PSTN/gateway traffic
# the '01' prefix specifies which port the gateway should use
route[3]
{
rewritehostport("192.168.1.244:5060");
forward(uri:host, uri:port);
break;
} /* end of route 3 - PSTN traffic*/
___________________________________
Hilco de Lathouder
New Bridges
Voice Processing Engineers
Calandstraat 44
3316 EA Dordrecht
The Netherlands (timezone: GMT+1)
+31 (78) 6548787
([22]lathouder(a)newbridges.nl)
References
Visible links
1. sip:%5B5-7
2. mailto:%5Esip:%5B5-7%5D%5B0-9%5D%7B2,3%7D@.*
3. sip:%5B0-9%5D%7B5,20%7D@.*
4. sip:%5B5-7
5. mailto:%5Esip:%5B5-7%5D%5B0-9%5D%7B2,3%7D@.*
6. sip:%5B0-9%5D%7B5,20%7D@.*
7. sip:%5B5-7
8. mailto:%5Esip:%5B5-7%5D%5B0-9%5D%7B2,3%7D@.*
9. sip:%5B0-9%5D%7B5,20%7D@.*
10. sip:%5B5-7
11. mailto:%5Esip:%5B5-7%5D%5B0-9%5D%7B2,3%7D@.*
12. sip:%5B0-9%5D%7B5,20%7D@.*
13. sip:%5B5-7
14. mailto:%5Esip:%5B5-7%5D%5B0-9%5D%7B2,3%7D@.*
15. sip:%5B0-9%5D%7B5,20%7D@.*
16. sip:%5B5-7
17. mailto:%5Esip:%5B5-7%5D%5B0-9%5D%7B2,3%7D@.*
18. sip:%5B0-9%5D%7B5,20%7D@.*
19. sip:%5B5-7
20. mailto:%5Esip:%5B5-7%5D%5B0-9%5D%7B2,3%7D@.*
21. sip:%5B0-9%5D%7B5,20%7D@.*
22. mailto:lathouder@NewBridges.nl
Hidden links:
23.
http://www.databadge.net/igv2005/reg/?link=61dba23572386211a324