[OpenSER-Users] Problem with Mediaproxy
Daniel
d.grotti at gmail.com
Fri Dec 7 13:59:16 CET 2007
Hi,
this is my call flow (from client side making the call: 192.168.10.224):
The INVITE received by 192.168.0.167 (sent by 192.168.10.224 and processed
by proxy) has SDP body with PRIVATE IP and PORT.
-----------------------------------------------------------------------------------
# 192.162.10.224 ----> PROXY
Request-Line: INVITE sip:franco.callegati at PROXY_IP SIP/2.0
Message Header
Via: SIP/2.0/UDP 192.168.10.224:64244
;branch=z9hG4bK-d87543-9947ff15e2520b54-1--d87543-
Max-Forwards: 70
Contact: <sip:daniel.grotti at 192.168.10.224:64244>
To: "franco.callegati"<sip:franco.callegati at PROXY_IP>
From: "casa"<sip:daniel.grotti at PROXY_IP>;tag=4554424c
Call-ID: YjRmZjU3ODAwMjIxMDU0MDUwNDllYzUwNmZiYTJjMmE.
CSeq: 2 INVITE
Allow: INVITE, ACK, CANCEL, OPTIONS, BYE, REFER, NOTIFY, MESSAGE,
SUBSCRIBE, INFO
Content-Type: application/sdp
Proxy-Authorization: Digest
username="1000",realm="PROXY_IP",nonce="47593c9fa32034a66fdb7493ff499c7215d4d8db",uri="sip:
franco.callegati at PROXY
_IP",response="82d21af18029aa02388869088c3619d2",algorithm=MD5
User-Agent: X-Lite release 1011s stamp 41150
Content-Length: 374
Message body
Session Description Protocol
Session Description Protocol Version (v): 0
Owner/Creator, Session Id (o): - 8 2 IN IP4 192.168.10.224
Session Name (s): CounterPath X-Lite 3.0
Connection Information (c): IN IP4 192.168.10.224
Time Description, active time (t): 0 0
Media Description, name and address (m): audio 53624 RTP/AVP 107
119 100 106 0 105 98 8 101
Media Attribute (a): fmtp:101 0-15
Media Attribute (a): rtpmap:107 BV32/16000
Media Attribute (a): rtpmap:119 BV32-FEC/16000
Media Attribute (a): rtpmap:100 SPEEX/16000
Media Attribute (a): rtpmap:106 SPEEX-FEC/16000
Media Attribute (a): rtpmap:105 SPEEX-FEC/8000
Media Attribute (a): rtpmap:98 iLBC/8000
Media Attribute (a): rtpmap:101 telephone-event/8000
Media Attribute (a): sendrecv
# PROXY -----> 192.162.10.224
Status-Line: SIP/2.0 100 Trying
Message Header
Via: SIP/2.0/UDP 192.168.10.224:64244
;branch=z9hG4bK-d87543-9947ff15e2520b54-1--d87543-;rport=28943;received=
85.18.14.25
To: "franco.callegati"<sip:franco.callegati at PROXY_IP>
From: "casa"<sip:daniel.grotti at PROXY_IP>;tag=4554424c
Call-ID: YjRmZjU3ODAwMjIxMDU0MDUwNDllYzUwNmZiYTJjMmE.
CSeq: 2 INVITE
Server: OpenSER (1.3.0-pre1-notls (i386/linux))
Content-Length: 0
# PROXY -----> 192.162.10.224
Status-Line: SIP/2.0 180 Ringing
Message Header
Via: SIP/2.0/UDP 192.168.10.224:64244;received=85.18.14.25
;branch=z9hG4bK-d87543-9947ff15e2520b54-1--d87543-;rport=28943
Record-Route: <sip:PROXY_IP:5060;lr;nat=yes;ftag=4554424c>
Contact: <sip:franco.callegati at 85.18.14.25
:42214;rinstance=96888d44783df4a0>
To: "franco.callegati"<sip:franco.callegati at PROXY_IP>;tag=d06d8b2d
From: "casa"<sip:daniel.grotti at PROXY_IP>;tag=4554424c
Call-ID: YjRmZjU3ODAwMjIxMDU0MDUwNDllYzUwNmZiYTJjMmE.
CSeq: 2 INVITE
User-Agent: X-Lite release 1011s stamp 41150
Content-Length: 0
# PROXY -----> 192.162.10.224
Status-Line: SIP/2.0 200 OK
Message Header
Via: SIP/2.0/UDP 192.168.10.224:64244;received=85.18.14.25
;branch=z9hG4bK-d87543-9947ff15e2520b54-1--d87543-;rport=28943
Record-Route: <sip:PROXY_IP:5060;lr;nat=yes;ftag=4554424c>
Contact: <sip:franco.callegati at 85.18.14.25
:42214;rinstance=96888d44783df4a0>
To: "franco.callegati"<sip:franco.callegati at PROXY_IP>;tag=d06d8b2d
From: "casa"<sip:daniel.grotti at PROXY_IP>;tag=4554424c
Call-ID: YjRmZjU3ODAwMjIxMDU0MDUwNDllYzUwNmZiYTJjMmE.
CSeq: 2 INVITE
Allow: INVITE, ACK, CANCEL, OPTIONS, BYE, REFER, NOTIFY, MESSAGE,
SUBSCRIBE, INFO
Content-Type: application/sdp
User-Agent: X-Lite release 1011s stamp 41150
Content-Length: 372
Message body
Session Description Protocol
Session Description Protocol Version (v): 0
Owner/Creator, Session Id (o): - 7 2 IN IP4 192.168.0.167
Session Name (s): CounterPath X-Lite 3.0
Connection Information (c): IN IP4 192.168.0.167
Time Description, active time (t): 0 0
Media Description, name and address (m): audio 45566 RTP/AVP 107
119 100 106 0 105 98 8 101
Media Attribute (a): fmtp:101 0-15
Media Attribute (a): rtpmap:107 BV32/16000
Media Attribute (a): rtpmap:119 BV32-FEC/16000
Media Attribute (a): rtpmap:100 SPEEX/16000
Media Attribute (a): rtpmap:106 SPEEX-FEC/16000
Media Attribute (a): rtpmap:105 SPEEX-FEC/8000
Media Attribute (a): rtpmap:98 iLBC/8000
Media Attribute (a): rtpmap:101 telephone-event/8000
Media Attribute (a): sendrecv
192.162.10.224 ----> PROXY
Request-Line: ACK
sip:franco.callegati at 85.18.14.25:42214;rinstance=96888d44783df4a0
SIP/2.0
Message Header
Via: SIP/2.0/UDP 192.168.10.224:64244
;branch=z9hG4bK-d87543-66641951d8357408-1--d87543-
Max-Forwards: 70
Route: <sip:PROXY_IP:5060;lr;nat=yes;ftag=4554424c>
Contact: <sip:daniel.grotti at 192.168.10.224:64244>
To: "franco.callegati"<sip:franco.callegati at PROXY_IP>;tag=d06d8b2d
From: "casa"<sip:daniel.grotti at PROXY_IP>;tag=4554424c
Call-ID: YjRmZjU3ODAwMjIxMDU0MDUwNDllYzUwNmZiYTJjMmE.
CSeq: 2 ACK
Proxy-Authorization: Digest
username="1000",realm="PROXY_IP",nonce="47593c9fa32034a66fdb7493ff499c7215d4d8db",uri="sip:
franco.callegati at PROXY
_IP",response="82d21af18029aa02388869088c3619d2",algorithm=MD5
User-Agent: X-Lite release 1011s stamp 41150
Content-Length: 0
RTP STREAM BETWEEN CLIENTS (MEDIAPROXY DOESN'T WORK)
CALL ENDED
----------------------------------------------------------------------------------------------------------------------
this is my config file:
debug=3
fork=yes
log_stderror=yes
listen=PROXY_IP
port=5060
children=4
dns=no
rev_dns=no
disable_dns_blacklist=yes
mpath="/usr/SER_proxy//lib/openser/modules/"
#------------------------------------------------------
# Load Module
#------------------------------------------------------
loadmodule "mysql.so"
loadmodule "auth.so"
loadmodule "auth_db.so"
loadmodule "sl.so"
loadmodule "tm.so"
loadmodule "rr.so"
loadmodule "maxfwd.so"
loadmodule "usrloc.so"
loadmodule "registrar.so"
loadmodule "mi_fifo.so"
loadmodule "uri.so"
loadmodule "uri_db.so"
loadmodule "domain.so"
loadmodule "mediaproxy.so"
loadmodule "nathelper.so"
loadmodule "textops.so"
loadmodule "xlog.so"
loadmodule "cpl-c.so"
loadmodule "alias_db.so"
#----------------------------------------------------------
# Parameters
#----------------------------------------------------------
modparam("auth_db|uri_db|usrloc|domain|alias_db", "db_url", "
mysql://topenser:openserrw@localhost/topenser")
modparam("mi_fifo", "fifo_name", "/tmp/openser_fifo")
modparam("auth_db", "calculate_ha1", yes)
modparam("auth_db", "password_column", "password")
modparam("usrloc", "db_mode", 2)
modparam("usrloc", "nat_bflag", 6)
modparam("rr", "enable_full_lr", 1)
modparam("alias_db", "use_domain", 1)
# REGISTRAR MODULE
modparam("registrar", "max_contacts", 2) # max number of contacts
per URI
modparam("registrar", "append_branches", 0) # if 0: R-URI will be
overwritten with the highest-q rated contact and the rest will be left
unprocessed.
modparam("registrar", "default_q", 1000) # default contacts
q-value set as 1
modparam("registrar", "received_avp","$avp(i:42)")
# URI_DB MODULE
modparam("uri_db", "use_uri_table", 1) # Specify if the "uri"
table should be used for checkings instead of "subscriber" table
# CPL MODULE
modparam("cpl-c", "db_url", "mysql://topenser:openserrw@localhost/topenser")
modparam("cpl-c", "cpl_table", "cpl")
modparam("cpl-c", "cpl_dtd_file", "/usr/src/openser-1.2.2-notls
/modules/cpl-c/cpl-06.dtd")
modparam("cpl-c", "lookup_domain", "location")
modparam("cpl-c","lookup_append_branches",1)
modparam("cpl-c","proxy_route", 10)
#NATHELPER MODULE
modparam("nathelper", "rtpproxy_disable_tout", 120)
modparam("nathelper", "rtpproxy_tout", 2)
modparam("nathelper", "natping_interval", 30)
modparam("nathelper", "ping_nated_only", 1)
modparam("nathelper", "received_avp", "$avp(i:42)")
modparam("nathelper", "sipping_method", "OPTIONS") # Use OPTIONS every
10sec to keep NAT alive
modparam("nathelper", "sipping_bflag", 6)
modparam("nathelper", "sipping_from", "sip:PROXY_IP")
#MEDIAPROXY MODULE
modparam("mediaproxy", "mediaproxy_socket", "/var/run/mediaproxy.sock")
modparam("mediaproxy", "sip_asymmetrics",
"/usr/local/etc/openser/sip-asymmetric-clients")
modparam("mediaproxy", "rtp_asymmetrics",
"/usr/local/etc/openser/rtp-asymmetric-clients")
# TM MODULE
modparam("tm", "fr_inv_timer", 120)
#------------------------------------------------------------
#MAIN ROUTE
#-----------------------------------------------------------
route {
xlog("L_DBG", "INFO: NEW REQUEST - METHOD=$rm R-URI=$ru FROM=$fu TO=$tu
IP=$si ID=$ci\n");
#------------------------------------
# Sanity checks
#------------------------------------
if (!mf_process_maxfwd_header("10"))
{ sl_send_reply("483", "Too much Hops");
exit;
};
if (msg:len >= 2048)
{ sl_send_reply("513", "Message too big");
exit;
};
#------------------------------------
# RECORD-ROUTE
#------------------------------------
if(method=="INVITE" && client_nat_test("7"))
{
record_route_preset ("PROXY_IP:5060;nat=yes");
xlog("L_DBG", "INFO: RECORD-ROUTE WITH NAT");
}
else if (method!="REGISTER")
{
record_route();
};
#----------------------------------------
# CALL TEAR DOWN
#----------------------------------------
if (method=="BYE")
{
end_media_session();
};
if (method=="CANCEL")
{
end_media_session();
};
#--------------------------------------------
# LOOSE ROUTE
#--------------------------------------------
if (loose_route())
{
xlog("L_DBG", "INFO: LOOSE ROUTE");
if (method=="INVITE")
{
if (!proxy_authorize("","subscriber"))
{ proxy_challenge("","0");
exit;
}
else if (!check_from())
{ sl_send_reply("403","Unauthorized");
exit;
};
consume_credentials();
if (client_nat_test("7") || search("^Route:.*nat=yes"))
{ setbflag(7);
use_media_proxy();
};
};
route(1);
exit;
};
#-------------------------------------------------
#CALL TYPE PROCESSING
#-------------------------------------------------
if (!uri==myself)
{ route(1);
exit;
};
if (uri==myself)
{
if (method=="REGISTER")
{ xlog("L_DBG", "INFO: REGISTER Message received");
route(2);
exit;
};
if (method=="ACK")
{ route(1);
exit;
};
if (method=="INVITE")
{
xlog("L_DBG", "INFO: INVITE Message received");
route(3);
exit;
};
if (method=="MESSAGE")
{
xlog("L_DBG", "INFO: MESSAGE method received");
route(4);
exit;
};
lookup("aliases");
if (!uri==myself)
{ route(1);
exit;
};
if (!lookup("location"))
{ sl_send_reply("404", "Destination not found");
exit;
};
};
route(1);
}
#--------------------------------------------------------
# REGISTER PROCESSING
#--------------------------------------------------------
route[2]
{
# Check credentials
if(!www_authorize("","subscriber"))
{ www_challenge("","0");
exit;
}
else if(!check_to())
{ sl_send_reply("401", "Unauthorized");
exit;
};
consume_credentials();
# Check client natted - if yes, set flag 6
if (!search("^Contact:[ ]*\*") && client_nat_test("7"))
{
setbflag(6);
xlog("L_DBG","INFO: Registration behind NAT");
xlog("L_DBG","INFO: Bflag 6, related to BRANCH=$T_branch_idx, is
setted as $bf");
fix_nated_register();
force_rport();
};
if(!save("location"))
{ sl_reply_error();
xlog("L_DBG", "Registration of [$fU] Failed");
};
xlog("L_DBG", "INFO: Registration of [$fU] Complete.");
xlog("L_DBG", "INFO: 200 OK has been sended");
}
#----------------------------------------------------------
# INVITE PROCESSING
#----------------------------------------------------------
route[3]
{
sl_send_reply("100", "Trying");
# Check if caller is natted, if yes set flag 7, rewrite Contact HF with
Proxy address
if(client_nat_test("7"))
{
setbflag(7);
xlog("L_DBG", "INFO: CLIENT INVITE BEHIND NAT");
xlog("L_DBG","NOTICE: Bflag 7, related to BRANCH=$T_branch_idx of
this INVITE, is setted as $bf");
if(force_rport())
{
xlog("L_DBG","INFO: rport FORCED");
};
if(fix_nated_contact())
{
xlog("L_DBG","INFO: Contact HF is now [$ct]");
};
# append_hf("P-hint: INVITE behind NAT \n");
};
# Check Credentials
if(!proxy_authorize("","subscriber"))
{ proxy_challenge("","0");
exit;
}
else if (!check_from())
{ sl_send_reply("403", "Unauthorized");
exit;
};
lookup("aliases");
if(uri!=myself)
{ route(1);
exit;
};
consume_credentials();
# Check if r-URI is an alias. If yes, rewrite RURI with User's URI
if(!alias_db_lookup("dbaliases"))
{
xlog("L_DBG", "The [$ru] is not an alias");
};
# Use Caller CPL "Outgoing" Script, if exist
if(!cpl_run_script("outgoing", "force_stateful"))
{
sl_send_reply("500","Outgoing CPL script execution
failed");
exit;
};
# Find destination user and re-write R-URI with its Contact
if (!lookup("location"))
{ sl_send_reply("404", "Destination not found");
exit;
};
xlog("L_DBG", "INFO: LOCATION HAS BEEN FOUND");
xlog("L_DBG","INFO: R-URI is now [$ru]");
t_on_reply("1");
# Use CPL "Incoming" script of the destination client
if(!cpl_run_script("incoming","force_stateful"))
{
sl_send_reply("500", "Incoming CPL script execution
failed");
exit;
};
route(11);
route(1);
}
# --------------------------------
# PROXY ROUTE - CPL SCRIPT LOADED
# --------------------------------
route[10]
{
xlog("L_DBG", "INFO: ROUTE 10 - PROXY ROUTE \n");
# append_hf("P-hint: CPL ROUTE 10 - PROXY-ROUTE\n");
if (isbflagset(6) || isbflagset(7))
{
xlog("L_DBG", "INFO: flag 6 or 7 setted \n");
if(!isbflagset(8))
{
setbflag(8);
};
if(use_media_proxy())
{
xlog("L_DBG","NOTICE: MEDIAPROXY in use for the CALLER!!");
# append_hf("P-hint: Mediaproxy in USE for the Caller\n");
};
};
}
# -----------------------------
# CONTROL FLAG - NO CPL SCRIPT
# -----------------------------
route[11]
{
xlog("L_DBG", "INFO: ROUTE 11 - NO CPL SCRIPT");
# append_hf("P-hint: ROUTE 11 \n");
if(isbflagset(6) || isbflagset(7))
{
xlog("L_DBG", "INFO: flag 6 or 7 setted");
if(!isbflagset(8))
{
setbflag(8);
};
if(use_media_proxy())
{
xlog("L_DBG","NOTICE: mediaproxy in use for
the caller!!");
# append_hf("P-hint: MEDIAPROXY in USE for the
CALLER\n");
};
};
}
# --------------------------------------------------
# MESSAGE PROCESSING
# --------------------------------------------------
route[4]
{
if (uri!=myself)
{ sl_send_reply ("403", "Forbidden");
exit;
};
if (!lookup("location"))
{ sl_send_reply("404", "Destination not found");
exit;
};
route(1);
}
#----------------------------------------------------
# RELEY ROUTE
#----------------------------------------------------
route[1]
{
if (!t_relay("0x01")) # don't send 100 trying
{
if (method=="INVITE" || method=="ACK")
{
end_media_session();
xlog("L_DBG","INFO: MEDIA SESSION ENDED");
};
sl_reply_error();
xlog("L_DBG", "INFO: SENT ERROR REPLY");
};
}
#---------------------------------------------------------------------
# On Reply Route
#---------------------------------------------------------------------
onreply_route[1]
{
xlog("L_DBG","INFO : ONREPLY ROUTE");
# append_hf("P-hint: ONREPLY ROUTE \n");
if (status=~"(180)|(183)|2[0-9][0-9]")
{
if (isbflagset(8) && !search("^Content-Lenght:[ ]*0"))
{
if(use_media_proxy())
{
xlog("L_DBG","INFO: MEDIAPROXY in use for the
CALLED!");
# append_hf("P-hint: Media Proxy in use for the
Callee!\n");
};
};
};
if (client_nat_test("7") && status=~"(180)|(183)|(200)")
{
fix_nated_contact();
xlog("L_DBG","INFO: CONTACT HF has been CHANGED");
# append_hf("P-hint: CALLEE'S CONTACT HF has benn CHANGED\n");
};
}
----------------------------------------------------------------------------------------------------------------------
Regards,
Daniel
Hi Daniel,
Can u post your openser configuration as well as a complete ngrep
trace for the calls you have problems with?
DanB
--
Daniel Grotti
________________________
e-mail : d.grotti at gmail.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.kamailio.org/pipermail/users/attachments/20071207/15bb3f97/attachment.htm
More information about the Users
mailing list