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 ***************************************************************************/
26 use DBD::Pg qw(:pg_types);
30 use lib qw{/var/www/ndawn/};
33 our $dbh = ND::DB::DB();
35 $dbh->do("SET CLIENT_ENCODING TO 'LATIN1';");
37 my $insert = $dbh->prepare("INSERT INTO dumps(tick,type,modified,dump) VALUES(?,?,?,?)");
38 my $select = $dbh->prepare("SELECT 1 FROM dumps WHERE type = ? AND modified = ?");
40 for my $type ("planet","alliance","galaxy"){
41 my @head = head("http://game.planetarion.com/botfiles/${type}_listing.txt");
42 $select->execute($type,$head[2]);
43 unless ($select->fetchrow){
44 my $file = get("http://game.planetarion.com/botfiles/${type}_listing.txt");
45 if ($file =~ /Tick: (\d+)/){
47 $insert->execute($1,$type,$head[2],$file);
54 `/var/www/ndawn/scripts/parsedumps.pl $updated`;
55 `/var/www/ndawn/scripts/ndrank.pl`;
56 $dbh->do("UPDATE misc SET value = ? WHERE id = 'TICK'", undef, $updated);