$c->forward('findBoard');
$board = $c->stash->{board};
+ if ( !defined $board->{fbid}){
+ $c->detach('/default');
+ }
my $threads = $dbh->prepare(q{SELECT ft.ftid,u.username,ft.subject
,count(NULLIF(COALESCE(fp.time > ftv.time,TRUE),FALSE)) AS unread,count(fp.fpid) AS posts
while (my $thread = $threads->fetchrow_hashref){
push @threads,$thread;
}
+
+ if ( !(defined $board->{post}) && @threads == 0){
+ $c->acl_access_denied('test',$c->action,'No access to board')
+ }
$c->stash(threads => \@threads);
+ $c->stash(title => "$board->{board} ($board->{category})");
+
$c->forward('listModeratorBoards', [$board->{fbid}]) if $board->{moderate};
}
my $dbh = $c->model;
$c->forward('findThread');
- unless ($c->stash->{thread}){
- $c->stash(template => 'access_denied.tt2');
+ $thread = $c->stash->{thread};
+ unless ($thread){
+ $c->stash(template => 'default.tt2');
+ $c->res->status(404);
return;
}
my $query = $dbh->prepare(q{SELECT uid,username FROM users u
JOIN forum_priv_access fta USING (uid) WHERE fta.ftid = $1});
- $query->execute($thread);
+ $query->execute($thread->{ftid});
$c->stash(access => $query->fetchall_arrayref({}) );
+ $c->stash(title => $thread->{subject}
+ . " ($thread->{category} - $thread->{board})");
$c->forward('findPosts');
$c->forward('markThreadAsRead') if $c->user_exists;
if ($c->stash->{thread}->{moderate}) {