Converted to use new style debug.

git-svn-id: http://svn.zoneminder.com/svn/zm/trunk@1476 e3e1d417-86f3-4887-817a-d78f3d33393f
pull/27/merge
stan 2005-06-23 08:34:19 +00:00
parent 3d6e828fc7
commit 4a3cbed69a
1 changed files with 112 additions and 43 deletions

View File

@ -77,7 +77,8 @@ use constant EVENT_PATH => ZM_PATH_WEB.'/'.ZM_DIR_EVENTS;
use constant LOG_FILE => ZM_PATH_LOGS.'/zmfilter.log';
use constant START_DELAY => 5; # How long to wait before starting
use constant CHECK_DELAY => 60; # How long between each event check
use constant VERBOSE => 0; # Whether to output more verbose debug
use constant DBG_LEVEL => 0; # 0 is errors, warnings and info only, > 0 for debug
if ( ZM_OPT_UPLOAD )
{
@ -136,6 +137,7 @@ if ( ZM_OPT_MESSAGE )
use DBI;
use POSIX;
use Time::HiRes qw/gettimeofday/;
use Date::Manip;
use Data::Dumper;
use Getopt::Long;
@ -159,6 +161,73 @@ Parameters are :-
exit( -1 );
}
my $dbg_id = "";
sub dbgInit
{
my $id = shift;
if ( $id )
{
$dbg_id = $id;
my $add_parms = shift;
if ( $add_parms )
{
foreach my $arg ( @ARGV )
{
if ( $arg =~ /^-(.*)$/ )
{
$dbg_id .= "_$1";
}
else
{
$dbg_id .= $arg;
}
}
}
}
}
sub dbgPrint
{
my $code = shift;
my $string = shift;
my $line = shift;
$string =~ s/[\r\n]+$//g;
my ($seconds, $microseconds) = gettimeofday();
if ( $line )
{
my $file = __FILE__;
$file =~ s|^.*/||g;
printf( "%s.%06d %s[%d].%s-%s/%d [%s]\n", strftime( "%x %H:%M:%S", localtime( $seconds ) ), $microseconds, $dbg_id, $$, $file, $line, $code, $string );
}
else
{
printf( "%s.%06d %s[%d].%s [%s]\n", strftime( "%x %H:%M:%S", localtime( $seconds ) ), $microseconds, $dbg_id, $$, $code, $string );
}
}
sub Debug
{
dbgPrint( "DBG", $_[0] ) if ( DBG_LEVEL >= 1 );
}
sub Info
{
dbgPrint( "INF", $_[0] ) if ( DBG_LEVEL >= 0 );
}
sub Warning
{
dbgPrint( "WAR", $_[0] ) if ( DBG_LEVEL >= -1 );
}
sub Error
{
dbgPrint( "ERR", $_[0] ) if ( DBG_LEVEL >= -2 );
}
#
# More or less replicates the equivalent PHP function
#
@ -185,12 +254,14 @@ sub DateTimeToSQL
my $dt_val = strtotime( $dt_str );
if ( !$dt_val )
{
print( STDERR "Error, unable to parse date string '$dt_str'\n" );
Error( "Unable to parse date string '$dt_str'\n" );
return( undef );
}
return( strftime( "%Y-%m-%d %H:%M:%S", localtime( $dt_val ) ) );
}
dbgInit( "zmfilter", 1 );
if ( !GetOptions( 'delay=i'=>\$delay ) )
{
Usage();
@ -208,7 +279,7 @@ chdir( EVENT_PATH );
my $dbh = DBI->connect( "DBI:mysql:database=".ZM_DB_NAME.";host=".ZM_DB_SERVER, ZM_DB_USER, ZM_DB_PASS );
print( "Scanning for events\n" );
Info( "Scanning for events\n" );
sleep( START_DELAY );
@ -219,7 +290,7 @@ while( 1 )
{
if ( (time() - $last_action) > ZM_FILTER_RELOAD_DELAY )
{
print( "Reloading filters\n" ) if ( VERBOSE );
Debug( "Reloading filters\n" );
$last_action = time();
$filters = getFilters();
}
@ -229,7 +300,7 @@ while( 1 )
checkFilter( $filter );
}
print( "Sleeping for $delay seconds\n" ) if ( VERBOSE );
Debug( "Sleeping for $delay seconds\n" );
sleep( $delay );
}
@ -265,7 +336,7 @@ sub getFilters
my $res = $sth->execute() or die( "Can't execute '$sql': ".$sth->errstr() );
FILTER: while( my $filter_data = $sth->fetchrow_hashref() )
{
print( "Found filter '$filter_data->{Name}'\n" ) if ( VERBOSE );
Debug( "Found filter '$filter_data->{Name}'\n" );
my %filter_terms;
foreach my $filter_parm ( split( '&', $filter_data->{Query} ) )
{
@ -275,7 +346,7 @@ sub getFilters
$filter_terms{$key} = $value;
}
}
#print( Dumper( %filter_terms ) );
#Debug( Dumper( %filter_terms ) );
my $sql = "select E.Id,E.MonitorId,M.Name as MonitorName,E.Name,E.StartTime,unix_timestamp(E.StartTime) as Time,E.Length,E.Frames,E.AlarmFrames,E.TotScore,E.AvgScore,E.MaxScore,E.Archived,E.Uploaded,E.Emailed,E.Messaged,E.LearnState from Events as E inner join Monitors as M on M.Id = E.MonitorId where not isnull(E.EndTime)";
my $filter_sql = '';
for ( my $i = 1; $i <= $filter_terms{trms}; $i++ )
@ -350,7 +421,7 @@ sub getFilters
$value = DateTimeToSQL( $temp_value );
if ( !$value )
{
print( STDERR "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
Error( "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
next FILTER;
}
$value = "'$value'";
@ -360,7 +431,7 @@ sub getFilters
$value = DateTimeToSQL( $temp_value );
if ( !$value )
{
print( STDERR "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
Error( "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
next FILTER;
}
$value = "to_days( '$value' )";
@ -370,7 +441,7 @@ sub getFilters
$value = DateTimeToSQL( $temp_value );
if ( !$value )
{
print( STDERR "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
Error( "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
next FILTER;
}
$value = "extract( hour_second from '$value' )";
@ -380,7 +451,7 @@ sub getFilters
$value = DateTimeToSQL( $temp_value );
if ( !$value )
{
print( STDERR "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
Error( "Error parsing date/time '$temp_value', skipping filter '$filter_data->{Name}'\n" );
next FILTER;
}
$value = "weekday( '$value' )";
@ -505,20 +576,20 @@ sub getFilters
{
$sql .= " limit 0, ".$filter_terms{limit};
}
print "SQL:$sql\n" if ( VERBOSE );
Debug( "SQL:$sql\n" );
$filter_data->{Sql} = $sql;
if ( $filter_data->{AutoExecute} )
{
my $script = $filter_data->{AutoExecute};
if ( !-e $script )
{
print( STDERR "Error, auto execute script '$script' not found, skipping filter '$filter_data->{Name}'\n" );
Error( "Auto execute script '$script' not found, skipping filter '$filter_data->{Name}'\n" );
next FILTER;
}
elsif ( !-x $script )
{
print( STDERR "Error, auto execute script '$script' not executable, skipping filter '$filter_data->{Name}'\n" );
Error( "Auto execute script '$script' not executable, skipping filter '$filter_data->{Name}'\n" );
next FILTER;
}
}
@ -533,7 +604,7 @@ sub checkFilter
{
my $filter = shift;
print( "Checking filter '$filter->{Name}'".
Debug( "Checking filter '$filter->{Name}'".
($filter->{AutoArchive}?", archive":"").
($filter->{AutoDelete}?", delete":"").
($filter->{AutoUpload}?", upload":"").
@ -541,7 +612,7 @@ sub checkFilter
($filter->{AutoMessage}?", message":"").
($filter->{AutoExecute}?", execute":"").
"\n"
) if ( VERBOSE );
);
my $sql = $filter->{Sql};
if ( $filter->{HasDiskPercent} )
@ -560,7 +631,7 @@ sub checkFilter
while( my $event = $sth->fetchrow_hashref() )
{
print( "Checking event $event->{Id}\n" ) if ( VERBOSE );
Debug( "Checking event $event->{Id}\n" );
if ( $filter->{AutoExecute} )
{
if ( !$event->{Execute} )
@ -591,7 +662,7 @@ sub checkFilter
}
if ( $filter->{AutoArchive} )
{
print( "Archiving event $event->{Id}\n" );
Info( "Archiving event $event->{Id}\n" );
# Do it individually to avoid locking up the table for new events
my $sql = "update Events set Archived = 1 where Id = ?";
my $sth = $dbh->prepare_cached( $sql ) or die( "Can't prepare '$sql': ".$dbh->errstr() );
@ -599,7 +670,7 @@ sub checkFilter
}
if ( $filter->{AutoDelete} )
{
print( "Deleting event $event->{Id}\n" );
Info( "Deleting event $event->{Id}\n" );
# Do it individually to avoid locking up the table for new events
my $sql = "delete from Events where Id = ?";
my $sth = $dbh->prepare_cached( $sql ) or die( "Can't prepare '$sql': ".$dbh->errstr() );
@ -618,10 +689,10 @@ sub checkFilter
my $command = "rm -rf ".ZM_DIR_EVENTS."/*/".sprintf( "%d", $event->{Id} );
my $output = qx($command);
my $status = $? >> 8;
if ( $status || VERBOSE )
if ( $status || DBG_LEVEL > 0 )
{
chomp( $output );
print( "Output: $output\n" );
Debug( "Output: $output\n" );
}
}
}
@ -639,17 +710,17 @@ sub executeCommand
my $command = $filter->{AutoExecute};
$command .= " $event_path";
print( "Executing '$command'\n" );
Info( "Executing '$command'\n" );
my $output = qx($command);
my $status = $? >> 8;
if ( $status || VERBOSE )
if ( $status || DBG_LEVEL > 0 )
{
chomp( $output );
print( "Output: $output\n" );
Debug( "Output: $output\n" );
}
if ( $status )
{
print( "Command '$command' exited with status: $status\n" );
Error( "Command '$command' exited with status: $status\n" );
}
else
{
@ -672,12 +743,12 @@ sub uploadArchFile
{
$arch_file .= '.zip';
my $zip = Archive::Zip->new();
print( "Creating upload file '$arch_file'\n" );
Info( "Creating upload file '$arch_file'\n" );
my $status = &AZ_OK;
foreach my $image_file ( <*$arch_image_path> )
{
print( "Adding $image_file\n" );
Info( "Adding $image_file\n" );
my $member = $zip->addFile( $image_file );
last unless ( $member );
$member->desiredCompressionMethod( (ZM_UPLOAD_ARCH_COMPRESS)?&COMPRESSION_DEFLATED:&COMPRESSION_STORED );
@ -686,7 +757,7 @@ sub uploadArchFile
if ( $arch_error = ($status != &AZ_OK) )
{
print( "Zip error: $status\n " );
Error( "Zip error: $status\n " );
}
}
elsif ( ZM_UPLOAD_ARCH_FORMAT eq "tar" )
@ -699,18 +770,18 @@ sub uploadArchFile
{
$arch_file .= '.tar';
}
print( "Creating upload file '$arch_file'\n" );
Info( "Creating upload file '$arch_file'\n" );
if ( $arch_error = !Archive::Tar->create_archive( $arch_file, ZM_UPLOAD_ARCH_COMPRESS, <*$arch_image_path> ) )
{
print( "Tar error: ".Archive::Tar->error()."\n " );
Error( "Tar error: ".Archive::Tar->error()."\n " );
}
}
if ( !$arch_error )
{
print( "Uploading to ".ZM_UPLOAD_FTP_HOST."\n" );
Info( "Uploading to ".ZM_UPLOAD_FTP_HOST."\n" );
my $ftp = Net::FTP->new( ZM_UPLOAD_FTP_HOST, Timeout=>ZM_UPLOAD_FTP_TIMEOUT, Passive=>ZM_UPLOAD_FTP_PASSIVE, Debug=>ZM_UPLOAD_FTP_DEBUG );
if ( !$ftp )
{
@ -746,14 +817,13 @@ sub sendEmail
return;
}
print( "Creating notification email\n" );
Info( "Creating notification email\n" );
my $subject = substituteTags( $email_subject, $filter, $event );
my @attachments;
my $body = substituteTags( $email_body, $filter, $event, \@attachments );
print( "Sending notification email '$subject'\n" );
print( "$body\n" ) if ( VERBOSE );
Info( "Sending notification email '$subject'\n" );
eval
{
@ -774,7 +844,7 @@ sub sendEmail
### Add the attachments
foreach my $attachment ( @attachments )
{
print( "Attaching '$attachment->{path}\n" );
Info( "Attaching '$attachment->{path}\n" );
$mail->attach(
Path => $attachment->{path},
Type => $attachment->{type},
@ -797,7 +867,7 @@ sub sendEmail
foreach my $attachment ( @attachments )
{
print( "Attaching '$attachment->{path}\n" );
Info( "Attaching '$attachment->{path}\n" );
$mail->attach(
Path => $attachment->{path},
Type => $attachment->{type},
@ -814,7 +884,7 @@ sub sendEmail
}
else
{
print( "Notification email sent\n" );
Info( "Notification email sent\n" );
}
my $sql = "update Events set Emailed = 1 where Id = ?";
my $sth = $dbh->prepare_cached( $sql ) or die( "Can't prepare '$sql': ".$dbh->errstr() );
@ -837,14 +907,13 @@ sub sendMessage
return;
}
print( "Creating notification message\n" );
Info( "Creating notification message\n" );
my $subject = substituteTags( $message_subject, $filter, $event );
my @attachments;
my $body = substituteTags( $message_body, $filter, $event, \@attachments );
print( "Sending notification message '$subject'\n" );
print( "$body\n" ) if ( VERBOSE );
Info( "Sending notification message '$subject'\n" );
eval
{
@ -865,7 +934,7 @@ sub sendMessage
### Add the attachments
foreach my $attachment ( @attachments )
{
print( "Attaching '$attachment->{path}\n" );
Info( "Attaching '$attachment->{path}\n" );
$mail->attach(
Path => $attachment->{path},
Type => $attachment->{type},
@ -888,7 +957,7 @@ sub sendMessage
foreach my $attachment ( @attachments )
{
print( "Attaching '$attachment->{path}\n" );
Info( "Attaching '$attachment->{path}\n" );
$mail->attach(
Path => $attachment->{path},
Type => $attachment->{type},
@ -905,7 +974,7 @@ sub sendMessage
}
else
{
print( "Notification message sent\n" );
Info( "Notification message sent\n" );
}
my $sql = "update Events set Messaged = 1 where Id = ?";
my $sth = $dbh->prepare_cached( $sql ) or die( "Can't prepare '$sql': ".$dbh->errstr() );