]> ruin.nu Git - ndwebbie.git/blobdiff - index.pl
intel link on check page, and red background for untaken calls
[ndwebbie.git] / index.pl
index 68276389f5ecd7b3f3bf9a43d54da2bf2e26d2fe..c0ab40fde76d2dffdf92943ec947832f18ed214b 100755 (executable)
--- a/index.pl
+++ b/index.pl
@@ -1,4 +1,4 @@
-#!/usr/bin/perl -w
+#!/usr/bin/perl -w -T
 #**************************************************************************
 #   Copyright (C) 2006 by Michael Andreen <harvATruinDOTnu>               *
 #                                                                         *
@@ -23,75 +23,113 @@ use CGI qw/:standard/;
 use HTML::Template;
 use DBI;
 use DBD::Pg qw(:pg_types);
+#use Apache2::Request;
 use strict;
 
-my $cgi = new CGI;
-
-chdir $ENV{'DOCUMENT_ROOT'};
+local $ND::DBH;
+local $ND::USER;
+local $ND::UID;
+local $ND::PLANET;
+local $ND::TEMPLATE;
+local $ND::BODY;
+local $ND::TICK;
 
 our $DBH = undef;
-our $UID = undef;
-our $PLANET = undef;
-our $TEMPLATE = undef;
-our $TICK = undef;
+our $USER = $ENV{'REMOTE_USER'};
+my $error;# = $ND::r->param('page');
+
+if ($ENV{'DOCUMENT_ROOT'} =~ m{((\w|/)+)}){
+       chdir $1;
+}
 
-$ND::TEMPLATE = HTML::Template->new(filename => 'templates/skel.tmpl');
+our $TEMPLATE = HTML::Template->new(filename => 'templates/skel.tmpl', global_vars => 1, cache => 1);
 
-for my $file ("db.pl"){
+for my $file ("db.pl","include.pl"){
        unless (my $return = do $file){
-               warn "couldn't parse $file: $@" if $@;
-               warn "couldn't do $file: $!"    unless defined $return;
-               warn "couldn't run $file"       unless $return;
+               print "couldn't parse $file: $@" if $@;
+               print "couldn't do $file: $!"    unless defined $return;
+               print "couldn't run $file"       unless $return;
        }
 }
 
-($UID,$PLANET) = $DBH->selectrow_array('SELECT uid,planet FROM users WHERE username = ?'
+our ($UID,$PLANET) = $DBH->selectrow_array('SELECT uid,planet FROM users WHERE username = ?'
        ,undef,$ENV{'REMOTE_USER'});
 
-($TICK) = $DBH->selectrow_array('SELECT tick()',undef);
+our ($TICK) = $DBH->selectrow_array('SELECT tick()',undef);
+
 
 my $query = $DBH->prepare('SELECT groupname,attack,gid from groupmembers NATURAL JOIN groups WHERE uid = ?');
 $query->execute($UID);
 
 our $ATTACKER = 0;
-our @GROUPS = ();
+undef our %GROUPS;
 while (my ($name,$attack,$gid) = $query->fetchrow()){
-       push @GROUPS,{name => $name, gid => $gid};
+       $GROUPS{$name} = $gid;
        $ATTACKER = 1 if $attack;
 }
 
 
-$TEMPLATE->param(Tick => $TICK);
-$TEMPLATE->param(isMember => 1);
-$TEMPLATE->param(isAttacker => $ATTACKER);
-
-
+our $LOG = $DBH->prepare('INSERT INTO log (uid,text) VALUES(?,?)');
 
 my $page = 'main';
-if (param('page') =~ /^(main)$/){
+if (param('page') =~ /^(main|check|motd|points|covop|top100|launchConfirmation|addintel|defrequest|raids|editRaid|calls|intel|users|alliances|memberIntel|resources|planetNaps)$/){
        $page = $1;
 }
 
-$ND::BODY = HTML::Template->new(filename => "templates/${page}.tmpl");
+our $XML = 0;
+$XML = 1 if param('xml') and $page =~ /^(raids)$/;
+
+our $AJAX = 1;
+
+my $type = 'text/html';
+if ($XML){
+       $type = 'text/xml';
+       $ND::TEMPLATE = HTML::Template->new(filename => "templates/xml.tmpl", cache => 1);
+       $ND::BODY = HTML::Template->new(filename => "templates/${page}.xml.tmpl", cache => 1);
+}else{
+       $ND::BODY = HTML::Template->new(filename => "templates/${page}.tmpl", global_vars => 1, cache => 1);
+       $ND::BODY->param(PAGE => $page);
+}
+
 
 unless (my $return = do "${page}.pl"){
-       print "couldn't parse $page: $@" if $@;
-       print "couldn't do $page: $!"    unless defined $return;
-       print "couldn't run $page"       unless $return;
+       $error .= "<p><b>couldn't parse $page: $@</b></p>" if $@;
+       $error .= "<p><b>couldn't do $page: $!</b></p>"    unless defined $return;
+       $error .= "<p><b>couldn't run $page</b></p>"       unless $return;
 }
 
-print header;
+unless ($XML){
+       my $fleetupdate = $DBH->selectrow_array('SELECT landing_tick FROM fleets WHERE uid = ? AND fleet = 0',undef,$UID);
+
+
+       $TEMPLATE->param(Tick => $TICK);
+       $TEMPLATE->param(isMember => (($TICK - $fleetupdate < 24) || isScanner()) && $PLANET && isMember());
+       $TEMPLATE->param(isHC => isHC());
+       $TEMPLATE->param(isDC => isDC());
+       $TEMPLATE->param(isBC => isBC());
+       $TEMPLATE->param(isIntel => isBC());
+       $TEMPLATE->param(isAttacker => $ATTACKER && (!isMember() || ((($TICK - $fleetupdate < 24) || isScanner()) && $PLANET)));
+       if ($ATTACKER && (!isMember() || ((($TICK - $fleetupdate < 24) || isScanner()) && $PLANET))){
+               $ND::TEMPLATE->param(Targets => listTargets());
+       }
+       $TEMPLATE->param(Coords => param('coords') ? param('coords') : '1:1:1');
+       $TEMPLATE->param(Error => $error);
+
+}
 $ND::TEMPLATE->param(BODY => $ND::BODY->output);
-print $TEMPLATE->output;
+my $output = $TEMPLATE->output;
+print header(-type=> $type, -charset => 'utf-8', -Content_Length => length $output);
+print $output;
 
 
 $DBH->disconnect;
 $DBH = undef;
 $UID = undef;
+$USER = undef;
 $PLANET = undef;
 $TEMPLATE = undef;
 $TICK = undef;
-@GROUPS = undef;
+undef %GROUPS;
 $ND::BODY = undef;
 
-exit;
+1;