use ND::Web::Page;
use ND::Web::Include;
-our @ISA = qw/ND::Web::Page/;
+use base qw/ND::Web::Page/;
sub noAccess () {
HTML::Template->new(filename => 'templates/NoAccess.tmpl', global_vars => 1, cache => 1);
sub process : method {
}
+sub listTargets () : method {
+ my $self = shift;
+ my $DBH = $self->{DBH};
+ my $query = $DBH->prepare(qq{SELECT t.id, r.id AS raid, r.tick+c.wave-1 AS landingtick, released_coords, coords(x,y,z),c.launched,c.wave,c.joinable
+FROM raid_claims c
+ JOIN raid_targets t ON c.target = t.id
+ JOIN raids r ON t.raid = r.id
+ JOIN current_planet_stats p ON t.planet = p.id
+WHERE c.uid = ? AND r.tick+c.wave > ? AND r.open AND not r.removed
+ORDER BY r.tick+c.wave,x,y,z});
+ $query->execute($ND::UID,$self->{TICK});
+ my @targets;
+ while (my $target = $query->fetchrow_hashref){
+ my $coords = "Target $target->{id}";
+ $coords = $target->{coords} if $target->{released_coords};
+ push @targets,{Coords => $coords, Launched => $target->{launched}, Raid => $target->{raid}
+ , Target => $target->{id}, Tick => $target->{landingtick}, Wave => $target->{wave}
+ , AJAX => $self->{AJAX}, JoinName => $target->{joinable} ? 'N' : 'J'
+ , Joinable => $target->{joinable} ? 'FALSE' : 'TRUE'};
+ }
+ my $template = HTML::Template->new(filename => "templates/targetlist.tmpl", cache => 1);
+ $template->param(Targets => \@targets);
+ return $template->output;
+}
+
+
sub render : method {
my $self = shift;
my $DBH = $self->{DBH};
$self->process;
my $type = 'text/html';
+ if ($self->{HTTP_ACCEPT} =~ m{application/xhtml\+xml}){
+ $type = 'application/xhtml+xml'
+ }
my $body;
if ($self->{XML}){
$type = 'text/xml';
$body = $self->render_body($body);
+ unless ($body){
+ return;
+ }
+
unless ($self->{XML}){
my $fleetupdate = $DBH->selectrow_array('SELECT landing_tick FROM fleets WHERE uid = ? AND fleet = 0',undef,$self->{UID});
$template->param(isIntel => $self->isBC());
$template->param(isAttacker => $ATTACKER && (!$self->isMember() || ((($TICK - $fleetupdate < 24) || $self->isScanner()) && $self->{PLANET})));
if ($ATTACKER && (!$self->isMember() || ((($TICK - $fleetupdate < 24) || $self->isScanner()) && $self->{PLANET}))){
- $template->param(Targets => listTargets());
+ $template->param(Targets => $self->listTargets);
}
$template->param(Coords => param('coords') ? param('coords') : '1:1:1');
my ($css) = $DBH->selectrow_array(q{SELECT css FROM users WHERE uid = $1},undef,$ND::UID);
$template->param(CSS => $css);
$template->param(TITLE => $self->{TITLE});
-
}
$template->param(Error => $ND::ERROR);
$template->param(BODY => $body->output);
my $output = $template->output;
print header(-type=> $type, -charset => 'utf-8', -Content_Length => length $output);
print $output;
-
-
- $DBH->rollback unless $DBH->{AutoCommit};
- $DBH->disconnect;
-
};
1;