2011-03-28 14:21:28 +00:00
< ?
authorize ();
if ( empty ( $_POST [ 'id' ]) || ! is_number ( $_POST [ 'id' ]) || empty ( $_POST [ 'type' ]) || ( $_POST [ 'type' ] != " request_update " && empty ( $_POST [ 'reason' ]))) {
error ( 404 );
}
include ( SERVER_ROOT . '/sections/reports/array.php' );
if ( ! array_key_exists ( $_POST [ 'type' ], $Types )) {
error ( 403 );
}
$Short = $_POST [ 'type' ];
$Type = $Types [ $Short ];
$ID = $_POST [ 'id' ];
if ( $Short == " request_update " ) {
if ( empty ( $_POST [ 'year' ]) || ! is_number ( $_POST [ 'year' ])) {
error ( 'Year must be specified.' );
header ( 'Location: reports.php?action=report&type=request_update&id=' . $ID );
die ();
}
$Reason = " [b]Year[/b]: " . $_POST [ 'year' ] . " . \n \n " ;
2012-10-02 08:00:20 +00:00
// If the release type is somehow invalid, return "Not given"; otherwise, return the release type.
2012-10-03 08:00:16 +00:00
$Reason .= " [b]Release Type[/b]: " . (( empty ( $_POST [ 'releasetype' ]) || ! is_number ( $_POST [ 'releasetype' ]) || $_POST [ 'releasetype' ] == 0 ) ? 'Not given' : $ReleaseTypes [ $_POST [ 'releasetype' ]]) . " . \n \n " ;
2011-03-28 14:21:28 +00:00
$Reason .= " [b]Additional Comments[/b]: " . $_POST [ 'comment' ];
} else {
$Reason = $_POST [ 'reason' ];
}
switch ( $Short ) {
case " request " :
case " request_update " :
$Link = 'requests.php?action=view&id=' . $ID ;
break ;
case " user " :
$Link = 'user.php?id=' . $ID ;
break ;
case " collage " :
$Link = 'collages.php?id=' . $ID ;
break ;
case " thread " :
$Link = 'forums.php?action=viewthread&threadid=' . $ID ;
break ;
case " post " :
$DB -> query ( " SELECT p.ID, p.TopicID, (SELECT COUNT(ID) FROM forums_posts WHERE forums_posts.TopicID = p.TopicID AND forums_posts.ID<=p.ID) AS PostNum FROM forums_posts AS p WHERE ID= " . $ID );
list ( $PostID , $TopicID , $PostNum ) = $DB -> next_record ();
$Link = " forums.php?action=viewthread&threadid= " . $TopicID . " &post= " . $PostNum . " #post " . $PostID ;
break ;
case " requests_comment " :
$DB -> query ( " SELECT rc.RequestID, rc.Body, (SELECT COUNT(ID) FROM requests_comments WHERE ID <= " . $ID . " AND requests_comments.RequestID = rc.RequestID) AS CommentNum FROM requests_comments AS rc WHERE ID= " . $ID );
list ( $RequestID , $Body , $PostNum ) = $DB -> next_record ();
$PageNum = ceil ( $PostNum / TORRENT_COMMENTS_PER_PAGE );
$Link = " requests.php?action=view&id= " . $RequestID . " &page= " . $PageNum . " #post " . $ID . " " ;
break ;
case " torrents_comment " :
$DB -> query ( " SELECT tc.GroupID, tc.Body, (SELECT COUNT(ID) FROM torrents_comments WHERE ID <= " . $ID . " AND torrents_comments.GroupID = tc.GroupID) AS CommentNum FROM torrents_comments AS tc WHERE ID= " . $ID );
list ( $GroupID , $Body , $PostNum ) = $DB -> next_record ();
$PageNum = ceil ( $PostNum / TORRENT_COMMENTS_PER_PAGE );
$Link = " torrents.php?id= " . $GroupID . " &page= " . $PageNum . " #post " . $ID ;
break ;
case " collages_comment " :
$DB -> query ( " SELECT cc.CollageID, cc.Body, (SELECT COUNT(ID) FROM collages_comments WHERE ID <= " . $ID . " AND collages_comments.CollageID = cc.CollageID) AS CommentNum FROM collages_comments AS cc WHERE ID= " . $ID );
list ( $CollageID , $Body , $PostNum ) = $DB -> next_record ();
$PerPage = POSTS_PER_PAGE ;
$PageNum = ceil ( $PostNum / $PerPage );
$Link = " collage.php?action=comments&collageid= " . $CollageID . " &page= " . $PageNum . " #post " . $ID ;
break ;
}
$DB -> query ( " INSERT INTO reports
( UserID , ThingID , Type , ReportedTime , Reason )
VALUES
( " .db_string( $LoggedUser['ID'] ). " , " . $ID . " , '".$Short."' , '".sqltime()."' , '".db_string($Reason)."' ) " );
$ReportID = $DB -> inserted_id ();
2011-06-30 08:00:06 +00:00
$Channels = array ();
2011-03-28 14:21:28 +00:00
if ( $Short == " request_update " ) {
$Channels [] = " #requestedits " ;
$Cache -> increment ( 'num_update_reports' );
}
2012-08-16 08:00:18 +00:00
if ( in_array ( $Short , array ( 'collages_comment' , 'post' , 'requests_comment' , 'thread' , 'torrents_comment' ))) {
2011-06-30 08:00:06 +00:00
$Channels [] = " #forumreports " ;
}
2011-03-28 14:21:28 +00:00
foreach ( $Channels as $Channel ) {
2012-10-21 08:00:14 +00:00
send_irc ( " PRIVMSG " . $Channel . " : " . $ReportID . " - " . $LoggedUser [ 'Username' ] . " just reported a " . $Short . " : https:// " . SSL_SITE_URL . " / " . $Link . " : " . strtr ( $Reason , " \n " , " " ));
2011-03-28 14:21:28 +00:00
}
$Cache -> delete_value ( 'num_other_reports' );
header ( 'Location: ' . $Link );
?>