hello jiri,every one: Thanks help me.i use ser-0.9.0 version ser,client is windows messenger,messager registrar to sip server,it problem.
[root@localhost ser-0.9.0]# 17(25914) handle_subscription() entered 17(25914) parse_hfs(): Error while parsing headers 17(25914) handle_subscription(): Error while parsing message header 17(25914) handle_subscription about to send_reply and return -2 17(25914) SUBSCRIBE execute 17(25914) handle_subscription() entered 17(25914) parse_hfs(): Error while parsing headers 17(25914) handle_subscription(): Error while parsing message header 17(25914) handle_subscription about to send_reply and return -2 17(25914) SUBSCRIBE execute 13(25907) handle_subscription() entered 13(25907) parse_hfs(): Error while parsing headers 13(25907) handle_subscription(): Error while parsing message header 13(25907) handle_subscription about to send_reply and return -2 13(25907) SUBSCRIBE execute 18(25915) Binding '1008@10.167.16.179','sip:10.167.16.54:10749' has expired 17(25914) handle_subscription() entered 17(25914) parse_hfs(): Error while parsing headers 17(25914) handle_subscription(): Error while parsing message header 17(25914) handle_subscription about to send_reply and return -2 17(25914) SUBSCRIBE execute 12(25906) handle_subscription() entered 12(25906) parse_hfs(): Error while parsing headers 12(25906) handle_subscription(): Error while parsing message header 12(25906) handle_subscription about to send_reply and return -2 12(25906) SUBSCRIBE execute
This is my scripts
# ------------------ 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" loadmodule "/usr/local/lib/ser/modules/textops.so" loadmodule "/usr/local/lib/ser/modules/pa.so"
# Uncomment this if you want 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 --
#modparam("usrloc", "db_mode", 0) modparam("usrloc", "use_domain", 1) modparam("registrar", "use_domain", 1)
# Uncomment this if you want to use SQL database # for persistent storage and comment the previous line modparam("usrloc", "db_mode", 2)
# -- auth params -- # Uncomment if you are using auth module # modparam("auth_db", "db_url","mysql://ser:heslo@10.167.16.179/ser") 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("pa", "pa_domain", "10.167.16.179") modparam("pa", "db_url", "mysql:ser:heslo@10.167.16.179/ser") modparam("pa", "default_expires",50) #modparam("pa", "default_expires",3600)
# ------------------------- request routing logic -------------------
# main routing logic
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 >= max_len ) { sl_send_reply("513", "Message too big"); break; };
# if (src_ip==193.175.135.0/24){ # force_send_socket(smaug:5080); # forward(193.175.135.179); # 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 if (!method=="REGISTER") record_route();
# subsequent messages withing a dialog should take the # path determined by record-routing 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=="SUBSCRIBE") { if (!t_newtran()) { log(1, "newtran error\n"); sl_reply_error(); }; handle_subscription("registrar"); log(1,"SUBSCRIBE execute\n"); break; }; # if (method=="PUBLISH") # { # if (method=="PUBLISH") # { # if (!t_newtran()) # { # log(1, "newtran error\n"); # sl_reply_error(); # }; # handle_publish("registrar"); # log(1,"PUBLISH execute\n"); # break; # };
if (method=="REGISTER") {
# Uncomment this if you want to use digest authentication if (!www_authorize("", "subscriber")) { www_challenge("", "0"); break; };
save("location"); break; };
lookup("aliases"); if (!uri==myself) { append_hf("P-hint: outbound alias\r\n"); route(1); break; }; # native SIP destinations are handled using our USRLOC DB if (!lookup("location")) { sl_send_reply("404", "Not Found"); break; }; }; append_hf("P-hint: usrloc applied\r\n"); route(1); }
route[1] { # send it out now; use stateful forwarding as it works reliably # even for UDP2TCP if (!t_relay()) { sl_reply_error(); }; }
______________________________________
===================================================================