⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 h323detail2db.pl

📁 radius server在linux下的源码
💻 PL
📖 第 1 页 / 共 2 页
字号:
#!/usr/bin/perl## Author:       Peter Nixon <codemonkey@peternixon.net># Date:         August 2002 # Summary:      Extract information from Radius detail log and#		compare/insert/update a Postgresql database.# Copy Policy:  GNU Public Licence Version 2 or later# URL:          http://www.peternixon.net/code/# Supported:    PostgreSQL (tested on version 7.2 and 7.3.x) and FreeRadius# Copyright:    2002, 2003 Peter Nixon <codemonkey@petenixon.net>## This program is free software; you can redistribute it and/or modify# it under the terms of the GNU General Public License as published by# the Free Software Foundation; either version 2 of the License, or#  (at your option) any later version.## This program is distributed in the hope that it will be useful,# but WITHOUT ANY WARRANTY; without even the implied warranty of# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the# GNU General Public License for more details.## $Id: h323detail2db.pl,v 1.8 2003/06/16 12:23:27 pnixon Exp $## Modules that we use to get things done.require DBI;require Getopt::Long;## Program and File locations# gzcat - 'cat for .gz / gzip files' # If you don't have gzcat and do have gzip then use: ln gzip gzcat$GZCAT = "/usr/bin/zcat";# zcat - 'cat for .Z / compressed files'$ZCAT = "/usr/bin/zcat";# bzcat - 'cat for .bz2 files'$BZCAT = "/usr/bin/bzcat";# Default Variables$database    = "radius";$port        = "3306";$user        = "postgres";$password    = "";#### You should not have to modify anything below here$progname = "H323 Detail to DB parser";$version = 2;# Set up some basic variables$passno = 0; $double_match_no = 0; $verbose = 0;$starttime = time();sub db_connect {	my $hostname = shift;	if ($verbose > 1) { print "DEBUG: Connecting to Database Host: $hostname\n" }	if ($hostname eq 'localhost') {	if ($verbose > 1) { print "DEBUG: localhost connection so using UNIX socket instead of network socket.\n" }		$dbh = DBI->connect("DBI:Pg:dbname=$database", "$user", "$password")        	        or die "Couldn't connect to database: " . DBI->errstr;	}	else {		$dbh = DBI->connect("DBI:Pg:dbname=$database;host=$hostname", "$user", "$password")        	        or die "Couldn't connect to database: " . DBI->errstr;	}}sub db_disconnect {	### Now, disconnect from the database	if ($verbose > 1) { print "DEBUG: Disconnecting from Database Host: $hostname\n" }	$dbh->disconnect	    or warn "Disconnection failed: $DBI::errstr\n";}sub procedure_insert {	$passno++;	if ($verbose > 0) { print "Record: $passno) Conf ID: $h323_conf_id   Setup Time: $h323_setup_time  Call Length: $AcctSessionTime   "; }	if ($h323_call_type eq 'VoIP') {         $sth2 = $dbh->prepare("SELECT VoIPInsertRecord('$UserName', '$NasIPAddress', '$AcctSessionTime', '$AcctInputOctets', '$AcctOutputOctets',		'$Called_Station_Id', '$Calling_Station_Id', '$AcctDelayTime', '$h323_call_origin', '$h323_setup_time',		'$h323_connect_time','$h323_disconnect_time', '$h323_disconnect_cause', '$h323_remote_address', '$h323_voice_quality', '$h323_conf_id')");	}	elsif ($h323_call_type eq 'Telephony') {        $sth2 = $dbh->prepare("SELECT TelephonyInsertRecord('$UserName', '$NasIPAddress', '$AcctSessionTime', '$AcctInputOctets', '$AcctOutputOctets',		'$Called_Station_Id', '$Calling_Station_Id', '$AcctDelayTime', '$Cisco_NAS_Port', '$h323_call_origin',		'$h323_setup_time', '$h323_connect_time','$h323_disconnect_time', '$h323_disconnect_cause', '$h323_voice_quality', '$h323_conf_id')");	} else { print "ERROR: Unsupported h323calltype \"$h323_call_type\"\n" }	$sth2->execute(); 	if ($verbose > 0) { print "sent to DB\n"; }	$sth2->finish();}sub db_insert {	if ($h323_call_type eq 'VoIP') {         $sth2 = $dbh->prepare("INSERT into Stop$h323_call_type (		UserName, NASIPAddress, AcctSessionTime, AcctInputOctets, AcctOutputOctets, CalledStationId, CallingStationId,		AcctDelayTime, H323RemoteAddress, h323callorigin, h323confid,		h323connecttime, h323disconnectcause, h323disconnecttime, h323setuptime, h323voicequality)		values('$UserName', '$NasIPAddress', '$AcctSessionTime', '$AcctInputOctets', '$AcctOutputOctets',		'$Called_Station_Id', '$Calling_Station_Id', '$AcctDelayTime', '$h323_remote_address',		'$h323_call_origin', '$h323_conf_id', '$h323_connect_time', '$h323_disconnect_cause', '$h323_disconnect_time', '$h323_setup_time', '$h323_voice_quality')");	}	elsif ($h323_call_type eq 'Telephony') {        $sth2 = $dbh->prepare("INSERT into StopTelephony (UserName, NASIPAddress, AcctSessionTime,                AcctInputOctets, AcctOutputOctets, CalledStationId, CallingStationId, AcctDelayTime,                CiscoNASPort, h323callorigin, h323confid, h323connecttime, h323disconnectcause, h323disconnecttime, h323setuptime, h323voicequality)                values('$UserName', '$NasIPAddress', '$AcctSessionTime', '$AcctInputOctets', '$AcctOutputOctets',                '$Called_Station_Id', '$Calling_Station_Id', '$AcctDelayTime', '$Cisco_NAS_Port', '$h323_call_origin', '$h323_conf_id',		'$h323_connect_time', '$h323_disconnect_cause', '$h323_disconnect_time', '$h323_setup_time', '$h323_voice_quality')");	} else { print "ERROR: Unsupported h323calltype \"$h323_call_type\"\n" }	$sth2->execute();	#my $returned_rows = $sth2->rows; 	if ($verbose > 0) { print "added to DB\n"; }	$sth2->finish();}## This sub can be used to update data in an existing database if you have some fields not in the Database.sub db_update {	my $sth2= $dbh->prepare("UPDATE radacct SET CalledStationId = '$Called_Station_Id', 		AcctTerminateCause = '$AcctTerminateCause', H323RemoteAddress = '$h323_remote_address',		AcctStatusType = '$AcctStatusType', h323confid = '$h323_conf_id', h323calltype = '$h323_call_type',		CiscoNASPort = '$Cisco_NAS_Port', h323disconnectcause = '$h323_disconnect_cause',		h323connecttime = '$h323_connect_time', h323disconnecttime = '$h323_disconnect_time',		h323setuptime = '$h323_setup_time' WHERE AcctSessionId = 'AcctSessionId' AND UserName = '$UserName'		AND NASIPAddress = '$NasIPAddress' AND h323confid = '$h323_conf_id'");        $sth2->execute();        my $returned_rows = $sth2->rows;	if ($verbose > 0) { print " $returned_rows record(s) updated\n" }        $sth2->finish();}sub db_read {	$passno++;	if ($verbose > 0) { print "Record: $passno) Conf ID: $h323_conf_id   Setup Time: $h323_setup_time  Call Length: $AcctSessionTime   "; }	my $sth = $dbh->prepare("SELECT RadAcctId FROM Stop$h323_call_type		WHERE h323SetupTime = '$h323_setup_time'		AND NASIPAddress = '$NasIPAddress'		AND h323confid = '$h323_conf_id'")                or die "Couldn't prepare statement: " . $dbh->errstr;          my @data;          $sth->execute()             # Execute the query            or die "Couldn't execute statement: " . $sth->errstr;           my $returned_rows = $sth->rows;          if ($sth->rows == 0) {		&db_insert;          } elsif ($sth->rows == 1) {                if ($verbose > 0) { print "Exists in DB.\n"; }		# FIXME: Make updates an option!                #while (@data = $sth->fetchrow_array()) {                #my $dbAcctSessionId = $data[1];		##&db_update;                #}          } else {		$double_match_no++;		# FIXME: Log this somewhere!                print "********* More than One Match! We have a problem!\n";          }        $sth->finish;}sub read_record {	my $keepreading = 1;	@record = ();	while ($keepreading) {		$_ = <DETAIL>;		print "$_" if ($verbose > 1);		if ( /^$/ ) {			$keepreading = 0;		} else {			$record[++$#record] = $_;		}	}}sub process_record {	if ($verbose > 1) { print "DEBUG: Processing Record\n"; }	# Clear the variable we use.	$UserName = ""; $NasPort=""; $NasPortType="";	 $NasIPAddress = ""; $AcctStatusType=""; $AcctSessionTime="";	$AcctInputOctets=""; $AcctOutputOctets=""; $AcctTerminateCause="";	$ServiceType=""; $FramedProtocol=""; $FramedIPAddress="";	$Timestamp=""; $AcctDelayTime=""; $ConnectInfo=""; $Called_Station_Id="";	$SQL_User_Name=""; $Cisco_NAS_Port=""; $Client_IP_Address="";	$h323_remote_address=""; $h323_disconnect_cause=""; $h323_gw_id="";	$h323_conf_id=""; $h323_call_type=""; $h323_disconnect_time="";	$h323_connect_time=""; $h323_setup_time=""; $Calling_Station_Id="";	$h323_call_origin=""; $h323_voice_quality="";	foreach (@record) {  		# Collect data	# Initial cleanup of junk from the line of data	s/^\s+//;	# Strip leading spaces.    	chomp;		# Strip trailing CR	# Parse the line of data into variables.	$AcctStatusType = $_ if s/Acct-Status-Type = //;	# All the data we need is in Stop records.	if ($AcctStatusType eq "Start") {		if ($verbose > 1) { print "DEBUG: Skipping \"Start\" record\n"; }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -