I could implement openser as a registrar(only) server .Thanks to the team openser for the timely help.I would like to know what all can be done using
openser/kamailio as a registrar server alone. i.e. in the real world scenario how does openser can be useful as a registrar sever alone.I would
like to make myself clear by pointing to the below example. i can integrate openser and asterisk and make openser as a registrar (only)server and can
make use of asterisk for call functionality purposes.. Similarly, i would like to know where openser fits in (openser should only be used as a
registrar server again).
Your responses can speed up my research work..
>
> Saúl Ibarra wrote:
>
> You are doing save_location before authentication. You should first
> challenge the REGISTER for authentication and then do save_location.
>
> 2009/10/6, Rajesh <Rajesh.sreedharan@siptech.com>:
>
>
> Dear All,
> I would like my kamailio server to act (only) as a
> Registrar server. I have configured my kamilio for performing
> authentication successfully, but this time i find that authentication is
> not being done.Your views on my cfg is greatly appreciated.
>
> # ------------------ module loading ----------------------------------
> debug=3
> log_stderror=yes
> mpath="/usr/local/lib/kamailio/modules/"
>
> loadmodule "db_mysql.so"
> loadmodule "mi_fifo.so"
> loadmodule "sl.so"
> loadmodule "pv.so"
> loadmodule "usrloc.so"
> loadmodule "registrar.so"
> loadmodule "textops.so"
> loadmodule "uri_db.so"
>
> loadmodule "auth.so"
> loadmodule "auth_db.so"
>
> port=5060
> # ----------------- setting module-specific parameters ---------------
>
>
> # ----- mi_fifo params -----
> modparam("mi_fifo", "fifo_name", "/tmp/kamailio_fifo")
>
>
> # ----- auth_db params -----
> /* uncomment the following lines if you want to enable the DB based
> authentication */
> modparam("auth_db", "calculate_ha1", yes)
> modparam("auth_db", "password_column", "password")
> modparam("auth_db", "db_url","mysql://openser:openserrw@localhost/openser")
> modparam("auth_db", "load_credentials", "")
>
> # -- usrloc params --
>
> modparam("usrloc", "db_url",
> "mysql://openser:openserrw@192.168.64.75/openser")
>
>
> modparam("usrloc", "db_mode", 3)
>
> # ------------------------- request routing logic -------------------
>
> # main routing logic
>
> route{
>
> # initial sanity checks -- too long messages
> if (msg:len >= 2048 ) {
> sl_send_reply("513", "Message too big");
> exit;
> };
>
> if (!uri==myself) {
> sl_send_reply("400", "Bad destination, only register
> messages destined for this server are accepted");
> exit;
> };
>
> # the only valid message for the registrar is the register message
> # other messages are answered with an error message
> if (uri==myself) {
>
> if (method=="REGISTER") {
>
> sl_send_reply("100", "Trying");
>
> if(!save("location")) {
> sl_reply_error();
> };
> exit;
> } else {
> sl_send_reply("403", "Forbidden");
> exit;
> };
> };
>
> # Authentication route
>
>
> if (is_method("REGISTER"))
> {
> # authenticate the REGISTER requests (uncomment to enable auth)
> if (!www_authorize("192.168.64.75", "subscriber"))
> {
> www_challenge("192.168.64.75", "0");
> exit;
> }
> ###the following lines are uncommented
> if ($au!=$tU)
> {
> sl_send_reply("403","Forbidden auth ID");
> exit;
> }
> }
> else
> {
> # authenticate if from local subscriber (uncomment to enable auth)
> if (from_uri==myself)
> {
> if (!proxy_authorize("", "subscriber"))
> {
> proxy_challenge("", "0");
> exit;
> }
> if (is_method("PUBLISH"))
> {
> if ($au!=$tU) {
> sl_send_reply("403","Forbidden auth ID");
> exit;
> }
> } else {
> if ($au!=$fU) {
> sl_send_reply("403","Forbidden auth ID");
> exit;
> }
> }
>
> consume_credentials();
> # caller authenticated
> }
> }
> return;
> }
>
>
>
> --
> Regards,
> Rajesh
>