X-Git-Url: https://ruin.nu/git/?a=blobdiff_plain;f=ND.pm;h=cfa73e511dc8c08302357f9ea86b42df8aa6ebcd;hb=dfdaf29be0eb73b0b900ce3bced443120b1fca96;hp=c2bb6c0dc3ea39989602a4add5e6de8fee143e45;hpb=b0f108eb4600f42fe3391acbe86381ce0c2d4681;p=ndwebbie.git diff --git a/ND.pm b/ND.pm index c2bb6c0..cfa73e5 100755 --- a/ND.pm +++ b/ND.pm @@ -26,9 +26,13 @@ use DBD::Pg qw(:pg_types); use Apache2::Request; use ND::Include; use ND::DB; +use Tie::File; +use Fcntl 'O_RDONLY'; use strict; use warnings FATAL => 'all'; +tie our @PAGES, 'Tie::File', "/var/www/ndawn/code/pages", mode => O_RDONLY or die $!; + sub handler { local $ND::r = shift; local $ND::req = Apache2::Request->new($ND::r, POST_MAX => "1M"); @@ -52,7 +56,7 @@ sub handler { sub page { our $DBH = ND::DB::DB(); our $USER = $ENV{'REMOTE_USER'}; - my $error;# = $ND::r->param('page'); + my $error = ''; chdir '/var/www/ndawn/code'; @@ -62,6 +66,7 @@ sub page { ,undef,$ENV{'REMOTE_USER'}); our ($TICK) = $DBH->selectrow_array('SELECT tick()',undef); + $TICK = 0 unless defined TICK; my $query = $DBH->prepare('SELECT groupname,attack,gid from groupmembers NATURAL JOIN groups WHERE uid = ?'); @@ -77,13 +82,10 @@ sub page { our $LOG = $DBH->prepare('INSERT INTO log (uid,text) VALUES(?,?)'); - my $page = 'main'; - if ($ND::PAGE =~ /^(main|check|motd|points|covop|top100|launchConfirmation|addintel|defrequest|raids|editRaid|calls|intel|users|alliances|memberIntel|resources|planetNaps)$/){ - $page = $1; - } + $ND::PAGE = 'main' unless grep { /^$ND::PAGE$/ } @PAGES; our $XML = 0; - $XML = 1 if param('xml') and $page =~ /^(raids)$/; + $XML = 1 if param('xml') and $ND::PAGE =~ /^(raids)$/; our $AJAX = 1; @@ -91,22 +93,22 @@ sub page { 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); + $ND::BODY = HTML::Template->new(filename => "templates/$ND::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); + $ND::BODY = HTML::Template->new(filename => "templates/$ND::PAGE.tmpl", global_vars => 1, cache => 1); + $ND::BODY->param(PAGE => $ND::PAGE); } - - unless (my $return = do "${page}.pl"){ - $error .= "

couldn't parse $page: $@

" if $@; - $error .= "

couldn't do $page: $!

" unless defined $return; - $error .= "

couldn't run $page

" unless $return; + unless (my $return = do "$ND::PAGE.pl"){ + $error .= "

couldn't parse $ND::PAGE: $@

" if $@; + $error .= "

couldn't do $ND::PAGE: $!

" unless defined $return && defined $!; + $error .= "

couldn't run $ND::PAGE

" unless $return; } unless ($XML){ my $fleetupdate = $DBH->selectrow_array('SELECT landing_tick FROM fleets WHERE uid = ? AND fleet = 0',undef,$UID); + $fleetupdate = 0 unless defined $fleetupdate; $TEMPLATE->param(Tick => $TICK); $TEMPLATE->param(isMember => (($TICK - $fleetupdate < 24) || isScanner()) && $PLANET && isMember()); @@ -119,9 +121,9 @@ sub page { $ND::TEMPLATE->param(Targets => listTargets()); } $TEMPLATE->param(Coords => param('coords') ? param('coords') : '1:1:1'); - $TEMPLATE->param(Error => $error); } + $TEMPLATE->param(Error => $error); $ND::TEMPLATE->param(BODY => $ND::BODY->output); my $output = $TEMPLATE->output; print header(-type=> $type, -charset => 'utf-8', -Content_Length => length $output);