"; BML::set_status(403); # 403 Forbidden return; }; my $mode = $POST{'mode'}; if ($mode eq 'screen') { $title = $ML{'.title.screen'}; } elsif ($mode eq 'unscreen') { $title = $ML{'.title.unscreen'}; } elsif ($mode eq 'delete') { $title = $ML{'.title.delete'}; } else { $title = $ML{'Error'}; return $err->($ML{'.error.invalid_mode'}); } my $sth; my $remote = LJ::get_remote(); return $err->($ML{'.error.login'}) unless $remote; return $err->("") unless LJ::did_post(); my @talkids; foreach (keys %POST) { push @talkids, $1 if /^selected_(\d+)$/; } return $err->($ML{'.error.none_selected'}) unless @talkids; my $u = LJ::load_user($POST{'journal'}); return $err->($ML{'talk.error.bogusargs'}) unless $u && $u->{'clusterid'}; return $err->($LJ::MSG_READONLY_USER) if LJ::get_cap($u, "readonly"); my $dbcr = LJ::get_cluster_def_reader($u); my $jid = $u->{'userid'}; my $ditemid = $POST{'ditemid'}+0; my $commentlink = LJ::journal_base($u) . "/$ditemid.html"; my $itemid = $ditemid >> 8; my $log = $dbcr->selectrow_hashref("SELECT * FROM log2 WHERE journalid=? AND jitemid=?", undef, $jid, $itemid); return $err->($ML{'.error.inconsistent_data'}) unless $log && $log->{'anum'} == ($ditemid & 255); my $up = LJ::load_userid($log->{'posterid'}); # check permissions return $err->($ML{'.error.privs.screen'}) if $mode eq "screen" && ! LJ::Talk::can_screen($remote, $u, $up); return $err->($ML{'.error.privs.unscreen'}) if $mode eq "unscreen" && ! LJ::Talk::can_unscreen($remote, $u, $up); return $err->($ML{'.error.privs.delete'}) if $mode eq "delete" && ! LJ::Talk::can_delete($remote, $u, $up); # filter our talkids down to those that are actually attached to the log2 # specified. also, learn the state of all the items. my $in = join (',', @talkids); $sth = $dbcr->prepare("SELECT jtalkid, state FROM talk2 ". "WHERE journalid=? AND jtalkid IN ($in) ". "AND nodetype='L' AND nodeid=?"); $sth->execute($jid, $itemid); my %state; while (my ($id, $state) = $sth->fetchrow_array) { $state{$id} = $state; } @talkids = keys %state; # do the work: if ($mode eq "delete") { LJ::Talk::delete_comments($u, "L", $itemid, \@talkids); $body = "$commentlink}) . " p?>"; return; } elsif ($mode eq "unscreen") { LJ::Talk::unscreen_comments($u, $itemid, \@talkids); $body = "$commentlink}) . " p?>"; return; } elsif ($mode eq "screen") { LJ::Talk::screen_comments($u, $itemid, \@talkids); $body = "$commentlink}) . " p?>"; return; } } _code?> body=> page?> _c?>