Subversion Repositories computer_asset_manager_v1

Rev

Rev 27 | Rev 73 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
23 rodolico 1
#! /usr/bin/perl -w
2
 
32 rodolico 3
# Version 0.9 20160713 RWR
4
# Added ability to have individual owners receive a summary report
5
 
23 rodolico 6
use DBI;
7
use Cwd 'abs_path';
8
#use Data::Dumper;
9
use File::Basename;
10
use YAML::XS;
11
 
12
 
25 rodolico 13
 
32 rodolico 14
my $VERSION = '0.9';
23 rodolico 15
my $MY_DIRECTORY = abs_path(dirname(__FILE__) );
16
my $message; # the message to send
27 rodolico 17
# query to find all reports in last 24 hours. Assumes the script
18
# runs at the same time each day
25 rodolico 19
my $query = qq|select 
32 rodolico 20
                  backups.responsible_party 'mailto',
25 rodolico 21
                  backups_run.backups_run_id 'ID',
22
                  device.device_id 'Device ID',
23
                  device.name 'Source',
24
                  timediff( backups_run.end_time,backups_run.start_time ) 'Run Time',
25
                  backups_run.transferred_count 'Files',
26
                  round(backups_run.transferred_size/1024/1024,2) 'Size (M)',
27
                  backups_run.files_deleted 'Deleted',
28
                  backups_run.skipped 'Skipped',
29
                  round( backups_run.data_sent/1024/1024,2) 'Traffic (M)'
30
               from
31
                  backups_run
32
                  join backups using (backups_id)
33
                  join device using (device_id)
34
               where
27 rodolico 35
                  backups_run.start_time > date_sub( now(), interval 24 hour)
36
               order by Source
25 rodolico 37
               |;
38
 
23 rodolico 39
 
27 rodolico 40
# Find number of backups in the past 24 hours.                  
25 rodolico 41
my $count = qq/select count(*) 'Count' 
42
               from backups_run 
27 rodolico 43
               where
44
                  backups_run.start_time > date_sub( now(), interval 24 hour)/;
23 rodolico 45
 
27 rodolico 46
# looks for backups which did NOT happen in last 24 hours, but did
47
# happen in last 7 days, ie backups that did not make it.
25 rodolico 48
my $missing = qq/select 
49
                  device.device_id ID,
50
                  device.name name
51
               from
52
                  ( 
53
                     select distinct( backups_id ) 
54
                     from 
55
                        backups_run 
56
                     where 
27 rodolico 57
                        (datediff( now(),added_date) < 7 ) 
25 rodolico 58
                  ) last_five
59
                  left join
60
                  (
61
                     select 
62
                        distinct( backups_id ) 
63
                     from 
64
                        backups_run
65
                     where 
27 rodolico 66
                        backups_run.start_time > date_sub( now(), interval 24 hour)
25 rodolico 67
                  ) today using (backups_id)
68
                  join 
69
                     backups using (backups_id)
70
                  join 
71
                     device using (device_id)
72
               where 
73
                  today.backups_id is null
74
                  /;
75
 
76
 
23 rodolico 77
# following are used to find the configuration file
25 rodolico 78
my $confFileName = "rsbackupRead.conf.yaml";
23 rodolico 79
my @searchPaths = ( '/etc/camp', '/opt/camp', '/opt/camp/sysinfo', $MY_DIRECTORY );
80
 
81
 
82
sub loadConfig {
83
   my ( $confFileName, @searchPaths ) = @_;
84
   my $configuration;
85
   for ( $i = 0; $i < @searchPaths; $i++ ) {
86
      $filename = $searchPaths[$i] . '/' . $confFileName;
87
      if ( -e $filename ) {
88
         #print "Found $filename\n";
89
         open CONF, "<$filename" or warn "Could not read $filename: $!\n";
90
         $configuration = Load( join( '', <CONF> ) );
91
         close CONF;
92
         last; # exit out of the loop; we don't try to load it more than once
93
      } # if
94
   } # foreach
95
   return $configuration;
96
} # sub loadConfig
97
 
98
sub sendReport {
99
   my ($parameters,$report) = @_;
100
   my %CLIParams ;
101
   $CLIParams{'-f'}  = qq/$$parameters{'mailFrom'}/    if $$parameters{'mailFrom'};
102
   $CLIParams{'-t'}  = qq/$$parameters{'mailTo'}/      if $$parameters{'mailTo'};
103
   $CLIParams{'-u'}  = qq/$$parameters{'mailSubject'}/ if $$parameters{'mailSubject'};
104
   $CLIParams{'-s'}  = qq/$$parameters{'mailServer'}/  if $$parameters{'mailServer'};
105
   $CLIParams{'-xu'} = qq/$$parameters{'smtpUser'}/    if $$parameters{'smtpUser'};
106
   $CLIParams{'-xp'} = qq/$$parameters{'smtpPass'}/    if $$parameters{'smtpPass'};
107
   $CLIParams{'-cc'} = qq/$$parameters{'mailCC'}/      if $$parameters{'mailCC'};
108
   $CLIParams{'-bcc'}= qq/$$parameters{'mailBCC'}/     if $$parameters{'mailBCC'};
109
   $CLIParams{'-l'}  = qq/$$parameters{'logFile'}/     if $$parameters{'logFile'};
110
   $CLIParams{'-a'}  = qq/$$parameters{'attachment'}/  if $$parameters{'attachment'};
111
   $CLIParams{'-o tls='} = qq/$$parameters{'tls'}/     if $$parameters{'tls'};
112
 
113
   $commandLine = qq/$$parameters{'emailScript'}/;
114
   die "Could not find executable $commandLine in sendEmailScript\n" unless -x $commandLine;
115
   $commandLine .= ' -q'; # make it act quietly
116
   foreach my $key ( keys %CLIParams ) {
117
      # depending on whether the key ends in an = or not, we will or will not use a space
118
      # between the key and the parameter
119
      $commandLine .= $key =~ m/=$/ ? " $key'$CLIParams{$key}'" : " $key '$CLIParams{$key}'";
120
   }
121
   $commandLine .= ' ' . $$parameters{'otherCLParams'} if $$parameters{'otherCLParams'};
122
   open SENDMAIL, "|$commandLine" or die "Could not open [$commandLine]: $!\n";
123
   print SENDMAIL $report;
124
   close SENDMAIL;
125
} # sendReport
126
 
32 rodolico 127
sub individualReport {
128
   my $data = shift;
129
   my @report;
130
 
131
   for my $key ( 'Device ID', 'Run Time', 'Files', 'Size (M)', 'Deleted', 'Skipped', 'Traffic (M)' ) {
132
      push @report, "$key: " . $$data{$key} unless $key eq 'mailto';
133
   }
134
   return join( "\n", @report );
135
}
136
 
23 rodolico 137
########################################################################
138
# Main Program
139
########################################################################
140
 
141
# Read anything passed on STDIN to prepend to e-mail
142
while ( my $line = <> ) {
143
   $message .= $line;
144
}
145
 
146
my $configuration = &loadConfig( $confFileName, @searchPaths );
147
die "Could not find configuration file $confFileName in " . join( ', ', @searchPaths) . "\n" unless $configuration;
148
 
149
my $dbh = DBI->connect('DBI:mysql:' . $$configuration{'database'}{'database'},
150
                       $$configuration{'database'}{'databaseUsername'}, 
151
                       $$configuration{'database'}{'databasePassword'} )
152
         || die "Could not connect to database: $DBI::errstr";
153
 
154
my $sth = $dbh->prepare( $count );
155
$sth->execute();
156
my $results = $sth->fetchrow_hashref();
157
$message .= "$results->{Count} reports in last 24 hours\n";
158
$sth->finish();
159
 
25 rodolico 160
$results = $dbh->selectall_hashref( $missing, 'ID' );
161
if ( %$results ) {
162
   $message .= '='x40 . "\nWARNING, no backup reports for the following machines\n" . '='x40 . "\n";
163
   foreach my $device ( keys %$results ) {
164
      $message .= sprintf( "%6d\t%s\n", $device, $results->{$device}->{name} );
165
   }
166
   $message .= '='x40 . "\n\n";
167
}
168
 
32 rodolico 169
# we're going to reuse the mail configuration for the individual reports
170
# if any, so let's save the mailTo and mailSubject
171
my $saveMailTo = $$configuration{'sendReport'}->{'mailTo'};
172
my $saveSubject = $$configuration{'sendReport'}->{'mailSubject'};
173
 
23 rodolico 174
$results = $dbh->selectall_hashref( $query, 'ID' );
25 rodolico 175
$message .= 'Device  Device Name                               Run Time  Files Size (M) Delete   Skip     xfer' . "\n" . '='x40 . "\n";
23 rodolico 176
foreach my $id ( keys %$results ) {
25 rodolico 177
   $message .= sprintf( "%7u %-40s %9s %6u %8.2f %6u %6u %8.2f\n",
178
                  $results->{$id}->{'Device ID'} , 
179
                  $results->{$id}->{'Source'} , 
180
                  $results->{$id}->{'Run Time'} ,
181
                  $results->{$id}->{'Files'} ,
182
                  $results->{$id}->{'Size (M)'} ,
183
                  $results->{$id}->{'Deleted'} ,
184
                  $results->{$id}->{'Skipped'} ,
185
                  $results->{$id}->{'Traffic (M)'}
186
               );
32 rodolico 187
   if ( $results->{$id}->{'mailto'} ) {
188
      $$configuration{'sendReport'}->{'mailTo'} = $results->{$id}->{'mailto'};
189
      $$configuration{'sendReport'}->{'mailSubject'} = 'Backup Report for ' . $results->{$id}->{'Source'};
190
      &sendReport( $$configuration{'sendReport'}, &individualReport( $results->{$id} ) );
191
   }
192
 
23 rodolico 193
}
194
$dbh->disconnect();
32 rodolico 195
 
196
# reset mailTo and MailSubject to original values
197
$$configuration{'sendReport'}->{'mailTo'} = $saveMailTo;
198
$$configuration{'sendReport'}->{'mailSubject'} = $saveSubject;
199
 
200
 
201
#print $message;
23 rodolico 202
&sendReport( $$configuration{'sendReport'}, $message );
203
 
204
1;