3 /***************************************************************************
4 * Copyright (C) 2006 by Michael Andreen <harvATruinDOTnu> *
6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the *
18 * Free Software Foundation, Inc., *
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
20 ***************************************************************************/
27 use DBD::Pg qw(:pg_types);
32 use lib "$FindBin::Bin/../lib";
36 our $dbh = ND::DB::DB();
38 $dbh->do("SET CLIENT_ENCODING TO 'LATIN1';");
40 my $insert = $dbh->prepare("INSERT INTO dumps(tick,type,modified,dump) VALUES(?,?,?,?)");
41 my $select = $dbh->prepare("SELECT 1 FROM dumps WHERE type = ? AND modified = ?");
43 for my $type ("planet","alliance","galaxy"){
44 my @head = head("http://game.planetarion.com/botfiles/${type}_listing.txt");
45 $select->execute($type,$head[2]);
46 unless ($select->fetchrow){
47 my $file = get("http://game.planetarion.com/botfiles/${type}_listing.txt");
48 if (defined $file && $file =~ /Tick: (\d+)/){
50 $insert->execute($1,$type,$head[2],$file);
57 `perl $FindBin::Bin/parsealliances.pl $updated`;
58 `perl $FindBin::Bin/parseplanets.pl $updated`;
59 `perl $FindBin::Bin/parsegalaxies.pl $updated`;
60 `perl $FindBin::Bin/ndrank.pl`;
61 $dbh->do(q{UPDATE misc SET value = ? WHERE id = 'TICK'}, undef, $updated);
62 system 'killall','-USR1', 'ndbot.pl';
63 local $dbh->{Warn} = 0;