r8480@llin: dpavlin | 2005-10-12 13:14:43 +0200
[BackupPC.git] / bin / BackupPC_incPartsUpdate
1 #!/usr/local/bin/perl -w
2
3 use strict;
4 use lib "__INSTALLDIR__/lib";
5
6 use DBI;
7 use BackupPC::Lib;
8 use BackupPC::View;
9 use Data::Dumper;
10 use Time::HiRes qw/time/;
11 use POSIX qw/strftime/;
12 use BackupPC::SearchLib;
13 use Cwd qw/abs_path/;
14
15 my $path = abs_path($0);
16 $path =~ s#/[^/]+$#/#;
17 my $tarIncCreate = $path .= 'BackupPC_tarIncCreate';
18
19 die "can't find $tarIncCreate: $!\n" unless (-x $tarIncCreate);
20
21 my $debug = 0;
22 $|=1;
23
24 my $start_t = time();
25
26 my $t_fmt = '%Y-%m-%d %H:%M:%S';
27
28 my $hosts;
29 my $bpc = BackupPC::Lib->new || die;
30 my %Conf = $bpc->Conf();
31 my $TopDir = $bpc->TopDir();
32 my $beenThere = {};
33
34 my $dsn = $Conf{SearchDSN} || die "Need SearchDSN in config.pl\n";
35 my $user = $Conf{SearchUser} || '';
36
37 my $dbh = DBI->connect($dsn, $user, "", { RaiseError => 1, AutoCommit => 0 });
38
39 my $tar_dir = $Conf{InstallDir}.'/'.$Conf{GzipTempDir};
40
41 die "problem with $tar_dir, check GzipTempDir in configuration\n" unless (-d $tar_dir && -w $tar_dir);
42
43 #---- subs ----
44
45 sub fmt_time {
46         my $t = shift || return;
47         my $out = "";
48         my ($ss,$mm,$hh) = gmtime($t);
49         $out .= "${hh}h" if ($hh);
50         $out .= sprintf("%02d:%02d", $mm,$ss);
51         return $out;
52 }
53
54 sub curr_time {
55         return strftime($t_fmt,localtime());
56 }
57
58 #----- main
59
60 my $sth = $dbh->prepare( qq{
61         
62 select
63         backups.id as backup_id,
64         hosts.name as host,
65         shares.name as share,
66         backups.num as num
67 from backups
68         join shares on backups.hostid = shares.hostid
69                 and shares.id = backups.shareid
70         join hosts on shares.hostid = hosts.id
71 where inc_size < 0 and not inc_deleted
72 order by backups.date
73
74 } );
75
76 $sth->execute();
77
78 my $sth_inc_size = $dbh->prepare(qq{ update backups set inc_size = ? where id = ? });
79 my $sth_inc_deleted = $dbh->prepare(qq{ update backups set inc_deleted = ? where id = ? });
80
81 %BackupPC::SearchLib::Conf = %Conf;
82
83 while (my $row = $sth->fetchrow_hashref) {
84         my $tar_file = BackupPC::SearchLib::getGzipName($row->{'host'}, $row->{'share'}, $row->{'num'});
85         print curr_time, " ", $row->{'host'}, ":", $row->{'share'}, " #", $row->{'num'}, " -> $tar_file";
86
87         my $t = time();
88
89         my $cmd = qq{$tarIncCreate -h "$row->{'host'}" -s "$row->{'share'}" -n $row->{'num'} | gzip -9 > $tar_dir/$tar_file};
90         print STDERR "## $cmd\n" if ($debug);
91
92         system($cmd) == 0 or die "failed: $?";
93
94         my $size = (stat( "$tar_dir/$tar_file" ))[7];
95
96         printf(" %1.2f MB, dur: %s", ($size / 1024 / 1024), fmt_time(time() - $t));
97
98         if ($size > 45) {
99                 $sth_inc_size->execute($size, $row->{'backup_id'});
100                 $sth_inc_deleted->execute(0, $row->{'backup_id'});
101         } else {
102                 $sth_inc_deleted->execute(1, $row->{'backup_id'});
103                 unlink "$tar_dir/$tar_file" || die "can't delete $tar_dir/$tar_file: $!\n";
104                 print " EMPTY";
105         }
106         print "\n";
107
108         $dbh->commit;
109
110 }
111
112 undef $sth;
113 $dbh->disconnect;