-#!/usr/bin/perl -w
+#!/usr/bin/perl -w -T
#**************************************************************************
# Copyright (C) 2006 by Michael Andreen <harvATruinDOTnu> *
# *
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 $USER = $ENV{'REMOTE_USER'};
+my $error;# = $ND::r->param('page');
-our $TEMPLATE = HTML::Template->new(filename => 'templates/skel.tmpl');
+if ($ENV{'DOCUMENT_ROOT'} =~ m{((\w|/)+)}){
+ chdir $1;
+}
+
+our $TEMPLATE = HTML::Template->new(filename => 'templates/skel.tmpl', global_vars => 1, cache => 1);
for my $file ("db.pl","include.pl"){
unless (my $return = do $file){
our $LOG = $DBH->prepare('INSERT INTO log (uid,text) VALUES(?,?)');
my $page = 'main';
-if (param('page') =~ /^(main|check|motd|points|covop|top100|launchConfirmation|addintel|defrequest|raids|editRaid|calls|intel)$/){
+if (param('page') =~ /^(main|check|motd|points|covop|top100|launchConfirmation|addintel|defrequest|raids|editRaid|calls|intel|users|alliances|memberIntel|resources|planetNaps)$/){
$page = $1;
}
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");
- $ND::BODY = HTML::Template->new(filename => "templates/${page}.xml.tmpl");
+ $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");
+ $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 "<p><b>couldn't parse $page: $@</b></p>" if $@;
- print "<p><b>couldn't do $page: $!</b></p>" unless defined $return;
- print "<p><b>couldn't run $page</b></p>" 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;
}
unless ($XML){
$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);
$PLANET = undef;
$TEMPLATE = undef;
$TICK = undef;
-%GROUPS = undef;
+undef %GROUPS;
$ND::BODY = undef;
-exit;
+1;