use DBI;
use DBD::Pg qw(:pg_types);
use Apache2::Request;
-use ND::Include;
+use ND::Web::Include;
use ND::DB;
use Tie::File;
use Fcntl 'O_RDONLY';
local $ND::BODY;
local $ND::TICK;
local %ND::GROUPS;
+ local $ND::ERROR;
local $ND::PAGE = $ND::req->param('page');
if ($ENV{'SCRIPT_NAME'} =~ /(\w+)(\.(pl|php|pm))?$/){
sub page {
our $DBH = ND::DB::DB();
- my $error = '';
+ $DBH->do(q{SET timezone = 'GMT'});
+
+ our $ERROR = '';
chdir '/var/www/ndawn/code';
$ATTACKER = 1 if $attack;
}
-
- our $LOG = $DBH->prepare('INSERT INTO log (uid,text) VALUES(?,?)');
-
tie my @pages, 'Tie::File', "/var/www/ndawn/code/pages", mode => O_RDONLY, memory => 0 or die $!;
$ND::PAGE = 'main' unless grep { /^$ND::PAGE$/ } @pages;
}
unless (my $return = do "$ND::PAGE.pl"){
- $error .= "<p><b>couldn't parse $ND::PAGE: $@</b></p>" if $@;
- $error .= "<p><b>couldn't do $ND::PAGE: $!</b></p>" unless defined $return && defined $!;
- $error .= "<p><b>couldn't run $ND::PAGE</b></p>" unless $return;
+ $ERROR .= "<p><b>couldn't parse $ND::PAGE: $@</b></p>" if $@;
+ $ERROR .= "<p><b>couldn't do $ND::PAGE: $!</b></p>" unless defined $return && defined $!;
+ $ERROR .= "<p><b>couldn't run $ND::PAGE</b></p>" unless $return;
}
unless ($XML){
$fleetupdate = 0 unless defined $fleetupdate;
+ my ($unread) = $DBH->selectrow_array(q{
+ SELECT count(*) AS unread
+FROM forum_boards fb NATURAL JOIN forum_threads ft
+ JOIN forum_posts fp USING (ftid) LEFT OUTER JOIN
+ (SELECT * FROM forum_thread_visits WHERE uid = $1) ftv ON ftv.ftid = ft.ftid
+WHERE (ftv.time IS NULL OR fp.time > ftv.time) AND
+ fbid IN (SELECT fbid FROM forum_access WHERE gid IN (SELECT groups($1)))
+ },undef,$UID) or $ERROR .= p($DBH->errstr);
+
+ $TEMPLATE->param(UnreadPosts => $unread);
$TEMPLATE->param(Tick => $TICK);
$TEMPLATE->param(isMember => (($TICK - $fleetupdate < 24) || isScanner()) && $PLANET && isMember());
$TEMPLATE->param(isHC => isHC());
$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);