Logging CDRs into MySQL
prabhu s sugumaran
ace_prabhu at rediffmail.com
Sat Nov 8 03:09:37 CET 2008
Ivan,
Thanks for your response. FreeRadisu is able to connect to the MySQL database and write into the radacct table. However I am not ablle to set things up for logging the VSA attributes into the database. How to edit the dialup.conf for the VSA value logging. I edited the dialup.conf with the inset query for the VSAs as follows:
accounting_start_query = " \
INSERT INTO ${acct_table1} \
(IPC_SESSION_ID, IPC_SERVICE_TYPE, IPC_SESSION_SEQUENCE_NUM, \
IPC_POS_TRANSPORT_PROTOCOL, IPC_POS_TRANSPORT_PORT, IPC_POS_TRANSPORT_IP, \ .......
VALUES \
('%{IPC-Session-Id}', '%{IPC-Service-Type}', \
'%{IPC-Session-Sequence-Num}', \
'%{IPC-Pos-Transport-Protocol}', '%{IPC-Pos-Transport-Port}', '%{IPC-Pos-Transport-IP}', \
......
I removes all other queries fom the dialup.conf and just have the above one but to no avail.
Please suggest.
Regards,
Prabhu
On Thu, 06 Nov 2008 prabhu s sugumaran wrote :
>
>
>Hi,
>
>I am facing difficulties in integrating MySQL and FreeRadius for the accounting. I have setup the mysql with a database named 'radius'. I have also defined a table 'rt_cdr1' which is to be used to store the CDRs that come in the accounting request. I add the following statements in radiusd.conf.
>
>-----------
>
>accounting{
>detail
>sql
>}
>------
>
>Also in the mysql.conf I have the following :
>
>acct_table1="rt_cdr1"
>acct_table2="rt_cdr1"
>
>Is their any other configurations that needs to be done to make the free radius pump the accounting request into databas?..I serarched to no avail .
>
>The following is the output of 'radiusd -X -f' :
>
>
>
>ot at electron freeradius]#
>[root at electron freeradius]# /usr/local/sbin/radiusd -X -f
>FreeRADIUS Version 2.1.1, for host i686-pc-linux-gnu, built on Nov 5 2008 at 14:56:50
>Copyright (C) 1999-2008 The FreeRADIUS server project and contributors.
>There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
>PARTICULAR PURPOSE.
>You may redistribute copies of FreeRADIUS under the terms of the
>GNU General Public License v2.
>Starting - reading configuration files ...
>including configuration file /usr/local/etc/raddb/radiusd.conf
>including configuration file /usr/local/etc/raddb/proxy.conf
>including configuration file /usr/local/etc/raddb/clients.conf
>including files in directory /usr/local/etc/raddb/modules/
>including configuration file /usr/local/etc/raddb/modules/wimax
>including configuration file /usr/local/etc/raddb/modules/detail.example.com
>including configuration file /usr/local/etc/raddb/modules/radutmp
>including configuration file /usr/local/etc/raddb/modules/etc_group
>including configuration file /usr/local/etc/raddb/modules/chap
>including configuration file /usr/local/etc/raddb/modules/attr_rewrite
>including configuration file /usr/local/etc/raddb/modules/mac2ip
>including configuration file /usr/local/etc/raddb/modules/inner-eap
>including configuration file /usr/local/etc/raddb/modules/ippool
>including configuration file /usr/local/etc/raddb/modules/logintime
>including configuration file /usr/local/etc/raddb/modules/attr_filter
>including configuration file /usr/local/etc/raddb/modules/counter
>including configuration file /usr/local/etc/raddb/modules/digest
>including configuration file /usr/local/etc/raddb/modules/always
>including configuration file /usr/local/etc/raddb/modules/smbpasswd
>including configuration file /usr/local/etc/raddb/modules/checkval
>including configuration file /usr/local/etc/raddb/modules/passwd
>including configuration file /usr/local/etc/raddb/modules/sradutmp
>including configuration file /usr/local/etc/raddb/modules/krb5
>including configuration file /usr/local/etc/raddb/modules/mschap
>including configuration file /usr/local/etc/raddb/modules/detail.log
>including configuration file /usr/local/etc/raddb/modules/linelog
>including configuration file /usr/local/etc/raddb/modules/preprocess
>including configuration file /usr/local/etc/raddb/modules/detail
>including configuration file /usr/local/etc/raddb/modules/realm
>including configuration file /usr/local/etc/raddb/modules/expr
>including configuration file /usr/local/etc/raddb/modules/ldap
>including configuration file /usr/local/etc/raddb/modules/files
>including configuration file /usr/local/etc/raddb/modules/acct_unique
>including configuration file /usr/local/etc/raddb/modules/echo
>including configuration file /usr/local/etc/raddb/modules/sql_log
>including configuration file /usr/local/etc/raddb/modules/mac2vlan
>including configuration file /usr/local/etc/raddb/modules/pap
>including configuration file /usr/local/etc/raddb/modules/policy
>including configuration file /usr/local/etc/raddb/modules/unix
>including configuration file /usr/local/etc/raddb/modules/pam
>including configuration file /usr/local/etc/raddb/modules/exec
>including configuration file /usr/local/etc/raddb/modules/expiration
>including configuration file /usr/local/etc/raddb/eap.conf
>including configuration file /usr/local/etc/raddb/sql.conf
>including configuration file /usr/local/etc/raddb/sql/mysql/dialup.conf
>including configuration file /usr/local/etc/raddb/sql/mysql/counter.conf
>including configuration file /usr/local/etc/raddb/policy.conf
>including files in directory /usr/local/etc/raddb/sites-enabled/
>including configuration file /usr/local/etc/raddb/sites-enabled/inner-tunnel
>including configuration file /usr/local/etc/raddb/sites-enabled/default
>including dictionary file /usr/local/etc/raddb/dictionary
>main {
> prefix = "/usr/local"
> localstatedir = "/usr/local/var"
> logdir = "/usr/local/var/log/radius"
> libdir = "/usr/local/lib"
> radacctdir = "/usr/local/var/log/radius/radacct"
> hostname_lookups = no
> max_request_time = 30
> cleanup_delay = 5
> max_requests = 1024
> allow_core_dumps = no
> pidfile = "/usr/local/var/run/radiusd/radiusd.pid"
> checkrad = "/usr/local/sbin/checkrad"
> debug_level = 0
> proxy_requests = yes
> log {
> stripped_names = no
> auth = no
> auth_badpass = no
> auth_goodpass = no
> }
> security {
> max_attributes = 200
> reject_delay = 1
> status_server = yes
> }
>}
> client localhost {
> ipaddr = 127.0.0.1
> require_message_authenticator = no
> secret = "testing123"
> nastype = "other"
> }
> client 192.168.72.32 {
> require_message_authenticator = no
> secret = "secret"
> }
>radiusd: #### Loading Realms and Home Servers ####
> proxy server {
> retry_delay = 5
> retry_count = 3
> default_fallback = no
> dead_time = 120
> wake_all_if_all_dead = no
> }
> home_server localhost {
> ipaddr = 127.0.0.1
> port = 1812
> type = "auth"
> secret = "testing123"
> response_window = 20
> max_outstanding = 65536
> zombie_period = 40
> status_check = "status-server"
> ping_interval = 30
> check_interval = 30
> num_answers_to_alive = 3
> num_pings_to_alive = 3
> revive_interval = 120
> status_check_timeout = 4
> }
> home_server_pool my_auth_failover {
> type = fail-over
> home_server = localhost
> }
> realm example.com {
> auth_pool = my_auth_failover
> }
> realm LOCAL {
> }
>radiusd: #### Instantiating modules ####
> instantiate {
> Module: Linked to module rlm_exec
> Module: Instantiating exec
> exec {
> wait = no
> input_pairs = "request"
> shell_escape = yes
> }
> Module: Linked to module rlm_expr
> Module: Instantiating expr
> Module: Linked to module rlm_expiration
> Module: Instantiating expiration
> expiration {
> reply-message = "Password Has Expired "
> }
> Module: Linked to module rlm_logintime
> Module: Instantiating logintime
> logintime {
> reply-message = "You are calling outside your allowed timespan "
> minimum-timeout = 60
> }
> }
>radiusd: #### Loading Virtual Servers ####
>server inner-tunnel {
> modules {
> Module: Checking authenticate {...} for more modules to load
> Module: Linked to module rlm_pap
> Module: Instantiating pap
> pap {
> encryption_scheme = "auto"
> auto_header = no
> }
> Module: Linked to module rlm_chap
> Module: Instantiating chap
> Module: Linked to module rlm_mschap
> Module: Instantiating mschap
> mschap {
> use_mppe = yes
> require_encryption = no
> require_strong = no
> with_ntdomain_hack = no
> }
> Module: Linked to module rlm_unix
> Module: Instantiating unix
> unix {
> radwtmp = "/usr/local/var/log/radius/radwtmp"
> }
> Module: Linked to module rlm_eap
> Module: Instantiating eap
> eap {
> default_eap_type = "md5"
> timer_expire = 60
> ignore_unknown_eap_types = no
> cisco_accounting_username_bug = no
> max_sessions = 2048
> }
> Module: Linked to sub-module rlm_eap_md5
> Module: Instantiating eap-md5
> Module: Linked to sub-module rlm_eap_leap
> Module: Instantiating eap-leap
> Module: Linked to sub-module rlm_eap_gtc
> Module: Instantiating eap-gtc
> gtc {
> challenge = "Password: "
> auth_type = "PAP"
> }
> Module: Linked to sub-module rlm_eap_tls
> Module: Instantiating eap-tls
> tls {
> rsa_key_exchange = no
> dh_key_exchange = yes
> rsa_key_length = 512
> dh_key_length = 512
> verify_depth = 0
> pem_file_type = yes
> private_key_file = "/usr/local/etc/raddb/certs/server.pem"
> certificate_file = "/usr/local/etc/raddb/certs/server.pem"
> CA_file = "/usr/local/etc/raddb/certs/ca.pem"
> private_key_password = "whatever"
> dh_file = "/usr/local/etc/raddb/certs/dh"
> random_file = "/usr/local/etc/raddb/certs/random"
> fragment_size = 1024
> include_length = yes
> check_crl = no
> cipher_list = "DEFAULT"
> make_cert_command = "/usr/local/etc/raddb/certs/bootstrap"
> cache {
> enable = no
> lifetime = 24
> max_entries = 255
> }
> }
> Module: Linked to sub-module rlm_eap_ttls
> Module: Instantiating eap-ttls
> ttls {
> default_eap_type = "md5"
> copy_request_to_tunnel = no
> use_tunneled_reply = no
> virtual_server = "inner-tunnel"
> }
> Module: Linked to sub-module rlm_eap_peap
> Module: Instantiating eap-peap
> peap {
> default_eap_type = "mschapv2"
> copy_request_to_tunnel = no
> use_tunneled_reply = no
> proxy_tunneled_request_as_eap = yes
> virtual_server = "inner-tunnel"
> }
> Module: Linked to sub-module rlm_eap_mschapv2
> Module: Instantiating eap-mschapv2
> mschapv2 {
> with_ntdomain_hack = no
> }
> Module: Checking authorize {...} for more modules to load
> Module: Linked to module rlm_realm
> Module: Instantiating suffix
> realm suffix {
> format = "suffix"
> delimiter = "@"
> ignore_default = no
> ignore_null = no
> }
> Module: Linked to module rlm_files
> Module: Instantiating files
> files {
> usersfile = "/usr/local/etc/raddb/users"
> acctusersfile = "/usr/local/etc/raddb/acct_users"
> preproxy_usersfile = "/usr/local/etc/raddb/preproxy_users"
> compat = "no"
> }
> Module: Checking session {...} for more modules to load
> Module: Linked to module rlm_radutmp
> Module: Instantiating radutmp
> radutmp {
> filename = "/usr/local/var/log/radius/radutmp"
> username = "%{User-Name}"
> case_sensitive = yes
> check_with_nas = yes
> perm = 384
> callerid = yes
> }
> Module: Checking post-proxy {...} for more modules to load
> Module: Checking post-auth {...} for more modules to load
> Module: Linked to module rlm_attr_filter
> Module: Instantiating attr_filter.access_reject
> attr_filter attr_filter.access_reject {
> attrsfile = "/usr/local/etc/raddb/attrs.access_reject"
> key = "%{User-Name}"
> }
> }
>}
> modules {
> Module: Checking authenticate {...} for more modules to load
> Module: Checking authorize {...} for more modules to load
> Module: Linked to module rlm_preprocess
> Module: Instantiating preprocess
> preprocess {
> huntgroups = "/usr/local/etc/raddb/huntgroups"
> hints = "/usr/local/etc/raddb/hints"
> with_ascend_hack = no
> ascend_channels_per_line = 23
> with_ntdomain_hack = no
> with_specialix_jetstream_hack = no
> with_cisco_vsa_hack = no
> with_alvarion_vsa_hack = no
> }
> Module: Checking preacct {...} for more modules to load
> Module: Linked to module rlm_acct_unique
> Module: Instantiating acct_unique
> acct_unique {
> key = "User-Name, Acct-Session-Id, NAS-IP-Address, Client-IP-Address, NAS-Port"
> }
> Module: Checking accounting {...} for more modules to load
> Module: Linked to module rlm_detail
> Module: Instantiating detail
> detail {
> detailfile = "/usr/local/var/log/radius/radacct/%{Client-IP-Address}/detail-%Y%m%d"
> header = "%t"
> detailperm = 384
> dirperm = 493
> locking = no
> log_packet_header = no
> }
> Module: Instantiating attr_filter.accounting_response
> attr_filter attr_filter.accounting_response {
> attrsfile = "/usr/local/etc/raddb/attrs.accounting_response"
> key = "%{User-Name}"
> }
> Module: Checking session {...} for more modules to load
> Module: Checking post-proxy {...} for more modules to load
> Module: Checking post-auth {...} for more modules to load
> }
>radiusd: #### Opening IP addresses and Ports ####
>listen {
> type = "auth"
> ipaddr = *
> port = 0
> clients = "per_socket_clients"
> client 192.168.72.32 {
> require_message_authenticator = no
> secret = "secret"
> }
>}
>listen {
> type = "acct"
> ipaddr = *
> port = 0
>}
>Listening on authentication address * port 1812
>Listening on accounting address * port 1813
>Listening on proxy address * port 1814
>Ready to process requests.
> rad_recv: Accounting-Request packet from host 192.168.72.32 port 50000, id=38, length=774
> User-Name = "192.168.72.32"
> NAS-IP-Address = 192.168.72.32
> Acct-Status-Type = Stop
> Acct-Session-Id = "61505"
> NAS-Port-Type = Async
> NAS-Port = 1504
> Calling-Station-Id = "192.168.76.17"
> Called-Station-Id = "172.27.247.80\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000"
> IPC-Session-Id = 0x0000000000000000
> IPC-Service-Type = 0
> IPC-Session-Sequence-Num = 1504
> IPC-Pos-Transport-Protocol = 0
> IPC-Pos-Transport-Port = 51235
> IPC-Pos-Transport-IP = 192.168.76.17
> IPC-Pos-Transport-DNS = "192.168.76.17"
> IPC-Ingress-Transport-Protocol = 0
> IPC-Ingress-Transport-Port = 4444
> IPC-Ingress-Transport-IP = 192.168.72.32
> IPC-Ingress-Transport-DNS = "192.168.72.32"
> IPC-Host-Transport-Protocol = 0
> IPC-Host-Transport-Port = 8045
> IPC-Host-Transport-IP = 172.27.247.80
> IPC-Host-Transport-DNS = "172.27.247.80"
> IPC-Ingress-Interface-Number = 0
> IPC-Transaction-Identifier = "be3521eaac1bf659"
> IPC-Transaction-Protocol-Type = 2
> IPC-Visa-Transaction-Mode = 0
> IPC-Security-Protocol = 0
> IPC-Call-Start-Ingress-Sec = 1225958119
> IPC-Call-Start-Ingress-Msec = 680
> IPC-Call-Connect-Ingress-Sec = 1225958119
> IPC-Call-Connect-Ingress-Msec = 680
> IPC-Call-Hs-Comp-Time-Sec = 1225958119
> IPC-Call-Hs-Comp-Time-Msec = 680
> IPC-Call-End-Time-Sec = 1225958119
> IPC-Call-End-Time-Msec = 730
> IPC-Call-Durn-Connect-Disc = 0
> IPC-Call-Termination-Cause = 256
> IPC-Response-Time-Host = 0
> IPC-Transaction-Bytes-Sent-POS = 14
> IPC-Transaction-Bytes-Sent-Host = 9
> IPC-Transaction-Bytes-Received-POS = 9
> IPC-Transaction-Bytes-Received-Host = 12
> IPC-Transaction-Bytes-Lost = 0
> IPC-Duplicate-Transactions = 0
> IPC-Re-Transmission-Pos = 0
> IPC-Re-Transmission-Host = 0
> IPC-NTP-Timezone = "GMT"
> USR-Attr-33068 = 0x00000000
>+- entering group preacct {...}
>++[preprocess] returns ok
>[acct_unique] Hashing 'NAS-Port = 1504,Client-IP-Address = 192.168.72.32,NAS-IP-Address = 192.168.72.32,Acct-Session-Id = "61505",User-Name = "192.168.72.32"'
>[acct_unique] Acct-Unique-Session-ID = "b38696cc273b57fb".
>++[acct_unique] returns ok
>[suffix] No '@' in User-Name = "192.168.72.32", looking up realm NULL
>[suffix] No such realm "NULL"
>++[suffix] returns noop
>++[files] returns noop
>+- entering group accounting {...}
>[detail] expand: /usr/local/var/log/radius/radacct/%{Client-IP-Address}/detail-%Y%m%d -> /usr/local/var/log/radius/radacct/192.168.72.32/detail-20081106
>[detail] /usr/local/var/log/radius/radacct/%{Client-IP-Address}/detail-%Y%m%d expands to /usr/local/var/log/radius/radacct/192.168.72.32/detail-20081106
>[detail] expand: %t -> Thu Nov 6 19:26:25 2008
>++[detail] returns ok
>++[unix] returns ok
>[radutmp] expand: /usr/local/var/log/radius/radutmp -> /usr/local/var/log/radius/radutmp
>[radutmp] expand: %{User-Name} -> 192.168.72.32
>rlm_radutmp: Logout for NAS 192.168.72.32 port 1504, but no Login record
>++[radutmp] returns ok
>[attr_filter.accounting_response] expand: %{User-Name} -> 192.168.72.32
> attr_filter: Matched entry DEFAULT at line 12
>++[attr_filter.accounting_response] returns updated
>Sending Accounting-Response of id 38 to 192.168.72.32 port 50000
>Finished request 0.
>Cleaning up request 0 ID 38 with timestamp +10
>Going to the next request
>Ready to process requests.
>
>
>
>Please suggest.
>
>Thanks,
>Prabhu
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.freeradius.org/pipermail/freeradius-users/attachments/20081108/637ab237/attachment.html>
More information about the Freeradius-Users
mailing list