[SR-Users] Kamailio - passing registration to another sip server

Mike Patterson mike at geils.com
Thu Aug 25 15:38:12 CEST 2016


I have configured Kamailio to pass a registration request to another VoIP
provider.  The reason I am doing this is to provide a sip port for users
where the ISP is blocking SIP.  I am able to pass the registrations to the
VoIP provider but I'd like to have inbound calls working as well.  I see the
inbound invites coming into the Kamailio server but it appears that the
server does not 'know' about the UA that is registered 'through' the server
to the VoIP provider.  Can anyone tell me how to fix this problem?  Below is
my config.

 

Thank you,

 

Mike

 

#!KAMAILIO

#

# Edge proxy configuration

#

 

#!subst "/REGISTRAR_IP/xxxxxxxxxx/" #IP address of voip provider

#!subst "/REGISTRAR_PORT/5060/"

#!substdef "/FLOW_TIMER/20/"

 

debug=2

log_stderror=no

log_facility=LOG_LOCAL0

fork=yes

children=4

alias="example.com"

#mpath="/usr/lib64/kamailio/modules"

mpath="/usr/lib/x86_64-linux-gnu/kamailio/modules"

tcp_connection_lifetime=30 # FLOW_TIMER + 10

auto_aliases=no

mhomed=0

listen=udp:X.X.X.X:531 advertise X.X.X.X:531

alias="X.X.X.X:531"

alias=X.X.X.X:531

alias="X.X.X.X:531"

alias=X.X.X.X:531

 

port=531

####### Modules Section ########

 

loadmodule "tm.so"

loadmodule "sl.so"

#loadmodule "outbound.so"

loadmodule "rr.so"

loadmodule "path.so"

loadmodule "pv.so"

loadmodule "maxfwd.so"

loadmodule "xlog.so"

loadmodule "sanity.so"

loadmodule "ctl.so"

loadmodule "mi_rpc.so"

loadmodule "mi_fifo.so"

loadmodule "textops.so"

loadmodule "siputils.so"

loadmodule "rtimer.so"

loadmodule "sqlops.so"

 

# ----------------- setting module-specific parameters ---------------

 

# ----- mi_fifo params -----

modparam("mi_fifo", "fifo_name", "/tmp/kamailio_fifo")

 

# ----- tm params -----

modparam("tm", "failure_reply_mode", 3)

 

# ----- rr params -----

modparam("rr", "append_fromtag", 0)

 

####### Routing Logic ########

 

request_route {

        route(REQINIT);

 

        if (is_method("CANCEL")) {

                if (t_check_trans()) {

                       route(RELAY);

                }

                exit;

        }

 

        route(WITHINDLG);

 

        t_check_trans();

 

        if (is_method("REGISTER")) {

                remove_hf("Route");

                add_path();

                $du = "sip:REGISTRAR_IP:REGISTRAR_PORT";

        } else {

                if (is_method("INVITE|SUBSCRIBE"))

                       record_route();

 

                if ($si == "REGISTRAR_IP" && $sp == "REGISTRAR_PORT") {

                       if (!loose_route()) {

                        switch($rc) {

                        case -2:

                         sl_send_reply("403", "Forbidden");

                         exit;

                        default:

                         sl_reply_error();

                         exit;

                        }

                       }

 

                       t_on_failure("FAIL_OUTBOUND");

                } else {

                       if ($rU == $null) {

                        sl_send_reply("484", "Address Incomplete");

                        exit;

                       }

                       remove_hf("Route");

                       $du = "sip:REGISTRAR_IP:REGISTRAR_PORT";

               }

        }

 

        route(RELAY);

}

 

route[RELAY] {

        if (!t_relay()) {

                sl_reply_error();

        }

        exit;

}

 

route[REQINIT] {

        if (!mf_process_maxfwd_header("10")) {

                sl_send_reply("483","Too Many Hops");

                exit;

        }

 

        if(!sanity_check("1511", "7"))

        {

                xlog("Malformed SIP message from $si:$sp\n");

                exit;

        }

}

 

route[WITHINDLG] {

        if (has_totag()) {

                if (!loose_route()) {

                       switch($rc) {

                       case -2:

                        sl_send_reply("403", "Forbidden");

                        exit;

                       default:

                        if (is_method("ACK")) {

                         if ( t_check_trans() ) {

                          route(RELAY);

                          exit;

                         } else {

                          exit;

                         }

                        }

                        sl_send_reply("404","Not Found");

                       }

                } else {

                       if (is_method("NOTIFY")) {

                        record_route();

                       }

                       route(RELAY);

                }

                exit;

        }

}

 

onreply_route {

        if (!t_check_trans()) {

                drop;

        }

 

        if ($rm == "REGISTER" && $rs >= 200 && $rs <= 299) {

                remove_hf("Flow-Timer");

                if ($(hdr(Require)[*])=~"outbound")

                       insert_hf("Flow-Timer: FLOW_TIMER\r\n", "Call-ID");

        }

}

 

failure_route[FAIL_OUTBOUND]{

        if (t_branch_timeout() || !t_branch_replied()) {

                send_reply("430", "Flow Failed");

        }

}

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.sip-router.org/pipermail/sr-users/attachments/20160825/7ee071eb/attachment.html>


More information about the sr-users mailing list