Hi Klaus,
I've tried setbflag and everything work fine except for caller (from
Public IP) call to callee (behind NAT), it supposed to establish the
call via RTP Proxy, but due to OpenSER doesn't detect any flag/bflag
therefore the onreply route wasn't execute force_rtp_proxy. (but remote
peer is NATed)
I'll paste my configuration here, can you point out what mistakes I've
made?
## Register route
route[1] {
sl_send_reply("100", "Trying");
if(!www_authorize("", "subscriber")) {
www_challenge("", "0");
exit;
}
consume_credentials();
if(!check_to()) {
xlog("L_INFO", "REGISTER Spoofed To-URI detected - RURI=$ru
F=$fu T=$tu IP=$si ID=$ci\n");
sl_send_reply("403", "Spoofed To-URI Detected");
exit;
}
if(!search("^Contact:[ ]*\*") && nat_uac_test("19")) {
xlog("L_INFO", "DBG: REGISTER [$fu]($si) is NATED");
fix_nated_register();
setbflag(5);
}
if(!save("location")) {
sl_reply_error();
exit;
}
xlog("L_INFO", "DBG: REGISTER [$fu]($si) ($ua) Registration
SUCCESSFUL");
exit;
}
## Invite Route
route[3] {
if(nat_uac_test("19")) {
fix_nated_contact();
}
t_on_reply("1");
if(uri=~"^sip:10\*.+@.*" ||
uri=~"^sip:([A-Z][a-z])([A-Z][a-z]).+@*") {
if(uri=~"^sip:10\*") {
strip(3);
}
xlog("L_INFO", "DBG: P2P call [$fu]($si) to [$tu]");
if(!lookup("location")) {
xlog("L_INFO", "DBG: P2P Peer not found [$tu] from
[$fu]($si)");
sl_send_reply("404", "User Offline");
exit;
}
if(nat_uac_test("19")) {
t_on_reply("2");
force_rtp_proxy();
setflag(3);
xlog("L_INFO", "DBG: P2P call in NATed Environment - Force
RTP Proxy [$fu]($si) to [$tu]");
}
} else {
if(!proxy_authorize("", "subscriber")) {
xlog("L_INFO", "DBG: INVITE [$fu]($si) PROXY authentication
FAILED");
proxy_challenge("", "1");
exit;
}
if(!check_from()) {
xlog("L_INFO", "INVITE Spoofed From-URI detected - RURI=$ru
F=$fu T=$tu IP=$si ID=$ci\n");
sl_send_reply("403", "Spoofed From-URI Detected");
exit;
}
rewritehostport("1.2.3.4:5060");
}
t_on_failure("1");
t_relay();
xlog("L_INFO", "DBG: INVITE F-[$fu] T-[$tu] IP-[$si] UA-[$ua]
SUCCESSFUL");
}
## Onreply route for P2P call
onreply_route[2] {
if(nat_uac_test("1")) {
fix_nated_contact();
}
if(status=~"(180)|(183)|2[0-9][0-9]") {
if(!search("^Content-Length:[ ]*0")) {
if (isflagset(3) || isbflagset(5)) {
xlog("L_INFO", "DBG: [$fu]($si) - Onreply route need to
RTP proxy.");
force_rtp_proxy();
}
}
}
xlog("L_INFO", "DBG: On Reply - S=$rs D=$rr F=$fu T=$tu RURI=$ru");
}
Thanks,
David Loh
Klaus Darilion wrote:
David Loh
wrote:
Hi All,
I'm facing a situation for P2P call where it need to determine both
caller and callee network type,
except for both parties having direct (internet) connection (on Public
IP), the rest of combinations will implement force_rtp_proxy.
(the 4 combinations are: NAT-> NAT, NAT -> Public IP, Public IP
-> NAT, Public IP -> Public IP).
Wondering if I can use isflagset or fetch flag from remote peer
(callee) ? or is there any function that allow this to be happen ?
Usually you do it this way (pseudo code):
- configure NAT flag (e.g. flag 5).
http://www.openser.org/docs/modules/1.3.x/usrloc.html#AEN76
if (REGISTER) {
if (behind NAT)
setbflag(5)
save();
exit;
}
...call routing...
if (behind NAT)
setflag(6)
..
activate branch route
....
t_relay();
exit;
branch_route[1] {
if isflagset(6) || isbflagset(5)
force_rtpproxy();
...
do other NAT traversal stuff
...
}
regards
klaus
}