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';
$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;
$fleetupdate = 0 unless defined $fleetupdate;
- my ($unread) = $DBH->selectrow_array(q{SELECT count(NULLIF(COALESCE(fp.time > ftv.time,TRUE),FALSE)) AS unread
-FROM 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
+ 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 > 0 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);