[Users] How to configure acc modue
Bogdan-Andrei Iancu
bogdan at voice-system.ro
Wed Oct 18 21:48:03 CEST 2006
Hi,
the acc module does not generate CDRs, but start / stop events you can
use for generating CDRs
do you get the logs? be sure to set in the scrip the configured acc flags!!
regards,
bogdan
Madhusudan.Jarhad at lntinfotech.com wrote:
>
> Dear All,
> Here is very basic question from me.
> I have installed openser 1.1.0. I want to record the CDR / Accounts of
> calles and messages being processed. I have acc module in my
> opense.cfg and parameter setting is as follows
>
> # ----------------- SETTING MODULE-SPECIFIC PARAMETERS ---------------
>
> ## - - - - - - - - - - XLOG PARAMETERS - - - - - - - - - - - - - - -
> modparam("xlog", "force_color", 0)
>
> # - - - - - - - - - USRLOC PARAMS - - - - - - - - - - - - - - - - - -
>
> #modparam("usrloc", "db_mode", 1)
>
> # Uncomment this if you want to use SQL database
> # for persistent storage and comment the previous line
> modparam("usrloc", "db_mode", 2)
> modparam("usrloc", "db_url",
> "mysql://openser:openserrw@localhost/openser")
>
>
> # - - - - - - AUTH PARAMS - - - - - - - - - - - -
> # Uncomment if you are using auth module
> #
> 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")
> #modparam("alias_db", "user_column", "username")
> modparam("auth_db", "password_column", "password")
>
> ## - - - - - AUTH RADIUS - - - - -
> #modparam("auth_radius", "radius_config",
> "/usr/local/etc/radiusclient-ng/radiusclient.conf")
> #modparam("auth_radius", "service_type", 15)
>
> ## - - - - - RR MODULE PARAMETERS - - - - -
> # add value to ;lr param to make some broken UAs happy
> modparam("rr", "enable_full_lr", 1)
> modparam("rr", "append_fromtag", 1)
> modparam("rr", "enable_double_rr", 1)
> modparam("rr", "add_username", 1)
>
> ## - - - - - ACCOUNTING PARAMETERS - - - - - - - -
> modparam("acc", "detect_direction", 1)
> modparam("acc", "failed_transaction_flag", 1)
> modparam("acc", "report_cancels",1)
> modparam("acc", "report_ack", 1)
> modparam("acc", "early_media", 1)
> modparam("acc", "detect_direction", 1)
> modparam("acc", "report_cancels", 1)
> modparam("acc", "log_level", 1)
> modparam("acc", "log_flag", 1)
> modparam("acc", "log_missed_flag", 1)
> #modparam("acc", "log_extra", "ua=$hdr(User-Agent);uuid=$avp(i:123)")
> modparam("acc", "service_type", 15) # user 16 to set to Radius
> modparam("acc", "db_flag", 2)
> modparam("acc", "db_missed_flag", 3)
> modparam("acc", "db_url", "mysql://openser:openserrw@localhost/openser")
> modparam("acc", "db_table_acc", "acc")
> modparam("acc", "db_table_missed_calls", "missed_calls")
> modparam("acc", "db_missed_flag", 3)
> modparam("acc", "acc_sip_method_column", "sip_method")
> modparam("acc", "acc_from_uri_column", "from_uri")
> modparam("acc", "acc_fromtag_column", "fromtag")
> modparam("acc", "acc_to_uri_column", "to_uri")
> modparam("acc", "acc_totag_column", "totag")
> #modparam("acc", "acc_cseqno_column", "cseq_no")
> modparam("acc", "acc_sip_callid_column", "sip_callid")
> modparam("acc", "acc_time_column", "time")
> # for mysql-based accouting, use the names of the columns
> # for RADIUS-based accouting, use the names of the RADIUS AVPs
> #modparam("acc",
> "multi_leg_info","RAD_LEG_SRC=$avp(src);RAD_LEG_SRC=$avp(dst)")
>
> #modparam("acc", "multi_leg_info","leg_src=$avp(src);leg_dst=$avp(dst)")
> #modparam("avpops", "avp_aliases", "uuid=I:50")
> modparam("acc", "radius_config",
> "/usr/local/etc/radiusclient-ng/radiusclient.conf")
> #modparam("acc", "radius_config", "/etc/openser/radius/client.conf")
> #modparam("acc", "radius_flag", 2)
> #modparam("acc", "diameter_missed_flag", 3)
>
> #modparam("acc", "radius_extra", "Sip-RPid=$avp(s:rpid)
> Source-IP=$si; Source-Port=$sp"
> # Canonical-URI=$avp($can_uri); \
> #
> Billing-Party=$avp($billing_party); \
> #
> Divert-Reason=$avp(s:divert_reason); \
> #
> X-RTP-Stat=$avp(s:rtp_statistics); \
> # From-Header=$hdr(from); \
> # User-Agent=$hdr(user-agent); \
> # Contact=$hdr(contact); \
> # Event=$hdr(event)")
>
> ## - - - - - - JABBER SERVER CONFIGURATION - - - - - - - - -
> modparam("jabber", "jdomain", "jabber.sipserver.com=*")
> modparam("jabber", "db_url",
> "mysql://openser:openserrw@localhost/openser")
>
> modparam("jabber", "jdomain", "sipx.vshodc.lntinfotech.com")
>
>
> ## - - - - - - - - - - - SIPTRACE MODULES PARAMETERS - - - - - - - - -
> modparam("siptrace", "trace_flag", 0)
> modparam("siptrace", "db_url",
> "mysql://openser:openserrw@localhost/openser")
> modparam("siptrace", "trace_on", 1)
> modparam("siptrace", "table", "sip_trace")
> modparam("siptrace", "duplicate_uri", "sip:172.17.85.51:5888")
>
>
>
> # ------------------------- request routing logic -------------------
>
> # main routing logic
>
> route{
>
> ## ADDED BY MADHUSUDAN
> # avp_write("caller_id", $avp(name); #"$uuid");
> # avp_printf("i:20", "$avp($uuid): $fu");
> # xdbg("$Cbgi:20$Cxx [$avp(i:20)] $Cbrcseq$Cxx=[$hdr(cseq)]\n");
> # setflag(1); /* set for accounting (the same value as in log_flag!)*/
> # t_relay(); /* enter stateful mode now */
>
> ##
>
>
> sip_trace();
> # xlog("L_ERR", "time [$Tf] method <$rm> r-uri <$ru> 2nd via
> <$hdr(via[1])>\n");
> # setflag(1); /* set for accounting (the same value as in
> log_flag!)*/
> # t_relay(); /* enter stateful mode now */
>
> # if (t_newtran()) {
> # log("UAS logic");
> # t_reply("999","hello");
> # } else sl_reply_error();
>
> ################
> if (t_local_replied("all")) {
> log ("no reply received\n");
> }
>
> # 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");
> exit;
> };
>
> if (msg:len >= 2048 ) {
> sl_send_reply("513", "Message too big");
> exit;
> };
>
> # 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);
> };
>
> if (!uri==myself) {
> # mark routing logic in request
> append_hf("P-hint: outbound\r\n");
> # if you have some interdomain connections via TLS
> #if(uri=~"@tls_domain1.net") {
> # t_relay("tls:domain1.net");
> # exit;
> #} else if(uri=~"@tls_domain2.net") {
> # t_relay("tls:domain2.net");
> # exit;
> #}
> route(1);
> };
>
> # 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=="REGISTER") {
>
> # Uncomment this if you want to use digest
> authentication
> #if (!www_authorize("openser.org",
> "subscriber")) {
> # www_challenge("openser.org", "0");
> # exit;
> #};
>
> save("location");
> exit;
> };
>
> lookup("aliases");
> if (!uri==myself) {
> append_hf("P-hint: outbound alias\r\n");
> route(1);
> };
>
> # native SIP destinations are handled using our USRLOC DB
> if (!lookup("location")) {
> sl_send_reply("404", "Not Found");
> exit;
> };
> 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();
> };
>
> exit;
> }
>
>
> onreply_route[1] {
> if (t_check_status("1[0-9][0-9]")) {
> setflag(1);
> log("provisional reply received\n");
> if (t_check_status("183"))
> drop;
> }
> if (t_was_cancelled()) {
> log("transaction was cancelled by UAC\n");
> }
>
> }
>
> ###################################################################
> My need is to get the CDRs for events and volume like MESSAGES and
> download/file transfer respectively.
> Please help
> ______________________________________________________________________
>
>------------------------------------------------------------------------
>
>_______________________________________________
>Users mailing list
>Users at openser.org
>http://openser.org/cgi-bin/mailman/listinfo/users
>
>
More information about the Users
mailing list