7182f0dadeed692d22df78ba58decf6a5757f36a
[buildfarm-server.git] / scripts / purge_old_logs.pl
1 #!/usr/bin/perl
2
3 # Called by the user the web server runs as to clean up old database
4 # records and old build logs
5
6 use strict;
7 use warnings;
8 use DBI;
9 use Data::Dumper;
10
11 use vars qw($dbhost $dbname $dbuser $dbpass $dbport
12 );
13 require "$ENV{BFConfDir}/BuildFarmWeb.pl";
14
15 die "no dbname" unless $dbname;
16 die "no dbuser" unless $dbuser;
17
18 my $dsn="dbi:Pg:dbname=$dbname";
19 $dsn .= ";host=$dbhost" if $dbhost;
20 $dsn .= ";port=$dbport" if $dbport;
21
22 my $db = DBI->connect($dsn,$dbuser,$dbpass);
23
24 die $DBI::errstr unless $db;
25
26 my $del_sth = $db->prepare(q[
27        DELETE FROM build_status
28        WHERE snapshot < (now() - interval '3 months')
29       ]);
30 my $del_recent_sth = $db->prepare(q[
31        DELETE FROM build_status_recent_500
32        WHERE snapshot < (now() - interval '3 months')
33       ]);
34
35 $del_sth->execute();
36 $del_recent_sth->execute();
37
38 my $buildlogs = "$ENV{BFConfDir}/buildlogs";
39
40 my @dirs = `find $buildlogs -mindepth 1 -type d -ctime +95`;
41 foreach my $dir (@dirs) {
42   chomp $dir;
43   print `rm -rf $dir`;
44 }