mirror of
https://github.com/WhatCD/Gazelle.git
synced 2024-12-13 10:56:26 +00:00
289 lines
8.7 KiB
PHP
289 lines
8.7 KiB
PHP
|
<?
|
||
|
/*
|
||
|
* This is the backend of the AJAXy reports resolve (When you press the shiny submit button).
|
||
|
* This page shouldn't output anything except in error, if you do want output, it will be put
|
||
|
* straight into the table where the report used to be. Currently output is only given when
|
||
|
* a collision occurs or a POST attack is detected.
|
||
|
*/
|
||
|
|
||
|
if(!check_perms('admin_reports')) {
|
||
|
error(403);
|
||
|
}
|
||
|
authorize();
|
||
|
|
||
|
|
||
|
//Don't escape: Log message, Admin message
|
||
|
$Escaped = db_array($_POST, array('log_message','admin_message', 'raw_name'));
|
||
|
|
||
|
//If we're here from the delete torrent page instead of the reports page.
|
||
|
if(!isset($Escaped['from_delete'])) {
|
||
|
$Report = true;
|
||
|
} else if(!is_number($Escaped['from_delete'])) {
|
||
|
echo 'Hax occured in from_delete';
|
||
|
} else {
|
||
|
$Report = false;
|
||
|
}
|
||
|
|
||
|
$PMMessage = $_POST['uploader_pm'];
|
||
|
|
||
|
if(is_number($Escaped['reportid'])) {
|
||
|
$ReportID = $Escaped['reportid'];
|
||
|
} else {
|
||
|
echo 'Hax occured in the reportid';
|
||
|
die();
|
||
|
}
|
||
|
|
||
|
if($Escaped['pm_type'] != 'Uploader') {
|
||
|
$Escaped['uploader_pm'] = '';
|
||
|
}
|
||
|
|
||
|
$UploaderID = (int)$Escaped['uploaderid'];
|
||
|
if(!is_number($UploaderID)) {
|
||
|
echo 'Hax occuring on the uploaderid';
|
||
|
die();
|
||
|
}
|
||
|
|
||
|
$Warning = (int)$Escaped['warning'];
|
||
|
if(!is_number($Warning)) {
|
||
|
echo 'Hax occuring on the warning';
|
||
|
die();
|
||
|
}
|
||
|
|
||
|
$CategoryID = $Escaped['categoryid'];
|
||
|
if(!isset($CategoryID)) {
|
||
|
echo 'Hax occuring on the categoryid';
|
||
|
die();
|
||
|
}
|
||
|
|
||
|
$TorrentID = $Escaped['torrentid'];
|
||
|
$RawName = $Escaped['raw_name'];
|
||
|
|
||
|
if(($Escaped['resolve_type'] == "manual" || $Escaped['resolve_type'] == "dismiss" ) && $Report) {
|
||
|
if($Escaped['comment']) {
|
||
|
$Comment = $Escaped['comment'];
|
||
|
} else {
|
||
|
if($Escaped['resolve_type'] == "manual") {
|
||
|
$Comment = "Report was resolved manually";
|
||
|
} elseif($Escaped['resolve_type'] == "dismiss") {
|
||
|
$Comment = "Report was dismissed as invalid";
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$DB->query("UPDATE reportsv2 SET
|
||
|
Status='Resolved',
|
||
|
LastChangeTime='".sqltime()."',
|
||
|
ModComment = '".$Comment."',
|
||
|
ResolverID='".$LoggedUser['ID']."'
|
||
|
WHERE ID='".$ReportID."'
|
||
|
AND Status <> 'Resolved'");
|
||
|
|
||
|
if($DB->affected_rows() > 0) {
|
||
|
$Cache->delete_value('num_torrent_reportsv2');
|
||
|
$Cache->delete_value('reports_torrent_'.$TorrentID);
|
||
|
} else {
|
||
|
//Someone beat us to it. Inform the staffer.
|
||
|
?>
|
||
|
<table cellpadding="5">
|
||
|
<tr>
|
||
|
<td>
|
||
|
<a href="reportsv2.php?view=report&id=<?=$ReportID?>">Somebody has already resolved this report</a>
|
||
|
<input type="button" value="Clear" onclick="ClearReport(<?=$ReportID?>);" />
|
||
|
</td>
|
||
|
</tr>
|
||
|
</table>
|
||
|
<?
|
||
|
}
|
||
|
die();
|
||
|
}
|
||
|
|
||
|
if(!isset($Escaped['resolve_type'])) {
|
||
|
echo 'No resolve type';
|
||
|
die();
|
||
|
} else if (array_key_exists($_POST['resolve_type'], $Types[$CategoryID])) {
|
||
|
$ResolveType = $Types[$CategoryID][$_POST['resolve_type']];
|
||
|
} else if(array_key_exists($_POST['resolve_type'],$Types['master'])) {
|
||
|
$ResolveType = $Types['master'][$_POST['resolve_type']];
|
||
|
} else {
|
||
|
//There was a type but it wasn't an option!
|
||
|
echo 'HAX (Invalid Resolve Type)';
|
||
|
die();
|
||
|
}
|
||
|
|
||
|
|
||
|
$DB->query("SELECT ID FROM torrents WHERE ID = ".$TorrentID);
|
||
|
$TorrentExists = ($DB->record_count() > 0);
|
||
|
if(!$TorrentExists) {
|
||
|
$DB->query("UPDATE reportsv2
|
||
|
SET Status='Resolved',
|
||
|
LastChangeTime='".sqltime()."',
|
||
|
ResolverID='".$LoggedUser['ID']."',
|
||
|
ModComment='Report already dealt with (Torrent deleted)'
|
||
|
WHERE ID=".$ReportID);
|
||
|
|
||
|
$Cache->decrement('num_torrent_reportsv2');
|
||
|
}
|
||
|
|
||
|
if($Report) {
|
||
|
//Resolve with a parallel check
|
||
|
$DB->query("UPDATE reportsv2
|
||
|
SET Status='Resolved',
|
||
|
LastChangeTime='".sqltime()."',
|
||
|
ResolverID='".$LoggedUser['ID']."'
|
||
|
WHERE ID=".$ReportID."
|
||
|
AND Status <> 'Resolved'");
|
||
|
}
|
||
|
|
||
|
//See if it we managed to resolve
|
||
|
if($DB->affected_rows() > 0 || !$Report) {
|
||
|
//We did, lets do all our shit
|
||
|
if($Report) { $Cache->decrement('num_torrent_reportsv2'); }
|
||
|
|
||
|
|
||
|
if(isset($Escaped['upload'])) {
|
||
|
$Upload = true;
|
||
|
} else {
|
||
|
$Upload = false;
|
||
|
}
|
||
|
|
||
|
|
||
|
if($_POST['resolve_type'] == "tags_lots") {
|
||
|
$DB->query("INSERT IGNORE INTO torrents_bad_tags (TorrentID, UserID, TimeAdded) VALUES (".$TorrentID.", ".$LoggedUser['ID']." , '".sqltime()."')");
|
||
|
$DB->query("SELECT GroupID FROM torrents WHERE ID = ".$TorrentID);
|
||
|
list($GroupID) = $DB->next_record();
|
||
|
$Cache->delete_value('torrents_details_'.$GroupID);
|
||
|
$SendPM = true;
|
||
|
}
|
||
|
|
||
|
if($_POST['resolve_type'] == "folders_bad") {
|
||
|
$DB->query("INSERT IGNORE INTO torrents_bad_folders (TorrentID, UserID, TimeAdded) VALUES (".$TorrentID.", ".$LoggedUser['ID'].", '".sqltime()."')");
|
||
|
$DB->query("SELECT GroupID FROM torrents WHERE ID = ".$TorrentID);
|
||
|
list($GroupID) = $DB->next_record();
|
||
|
$Cache->delete_value('torrents_details_'.$GroupID);
|
||
|
$SendPM = true;
|
||
|
}
|
||
|
if($_POST['resolve_type'] == "filename") {
|
||
|
$DB->query("INSERT IGNORE INTO torrents_bad_files (TorrentID, UserID, TimeAdded) VALUES (".$TorrentID.", ".$LoggedUser['ID'].", '".sqltime()."')");
|
||
|
$DB->query("SELECT GroupID FROM torrents WHERE ID = ".$TorrentID);
|
||
|
list($GroupID) = $DB->next_record();
|
||
|
$Cache->delete_value('torrents_details_'.$GroupID);
|
||
|
$SendPM = true;
|
||
|
}
|
||
|
|
||
|
//Log and delete
|
||
|
if(isset($Escaped['delete']) && check_perms('users_mod')) {
|
||
|
$DB->query("SELECT Username FROM users_main WHERE ID = ".$UploaderID);
|
||
|
list($UpUsername) = $DB->next_record();
|
||
|
$Log = "Torrent ".$TorrentID." (".$RawName.") uploaded by ".$UpUsername." was deleted by ".$LoggedUser['Username'];
|
||
|
$Log .= ($Escaped['resolve_type'] == 'custom' ? "" : " for the reason: ".$ResolveType['title'].".");
|
||
|
if(isset($Escaped['log_message']) && $Escaped['log_message'] != "") {
|
||
|
$Log .= " ( ".$Escaped['log_message']." )";
|
||
|
}
|
||
|
delete_torrent($TorrentID);
|
||
|
write_log($Log);
|
||
|
} else {
|
||
|
$Log = "No log message (Torrent wasn't deleted)";
|
||
|
}
|
||
|
|
||
|
//Warnings / remove upload
|
||
|
if($Upload) {
|
||
|
$Cache->begin_transaction('user_info_heavy_'.$UploaderID);
|
||
|
$Cache->update_row(false, array('DisableUpload' => '1'));
|
||
|
$Cache->commit_transaction(0);
|
||
|
|
||
|
$DB->query("UPDATE users_info SET
|
||
|
DisableUpload='1'
|
||
|
WHERE UserID=".$UploaderID);
|
||
|
}
|
||
|
|
||
|
if($Warning > 0) {
|
||
|
$WarnLength = $Warning * (7*24*60*60);
|
||
|
$Reason = "Uploader of torrent (".$TorrentID.") ".db_string($RawName)." which was resolved with the preset: ".$ResolveType['title'].".";
|
||
|
if($Escaped['admin_message']) {
|
||
|
$Reason .= " (".$Escaped['admin_message'].").";
|
||
|
}
|
||
|
if($Upload) {
|
||
|
$Reason .= " (Upload privileges Removed).";
|
||
|
}
|
||
|
|
||
|
warn_user($UploaderID, $WarnLength, $Reason);
|
||
|
} else {
|
||
|
//This is a bitch for people that don't warn but do other things, it makes me sad.
|
||
|
$AdminComment = "";
|
||
|
if($Upload) {
|
||
|
//They removed upload
|
||
|
$AdminComment .= "Upload privileges removed by ".$LoggedUser['Username'];
|
||
|
$AdminComment .= "\nReason: Uploader of torrent (".$TorrentID.") ".db_string($RawName)." which was resolved with the preset: ".$ResolveType['title'].". (Report ID: $ReportID)";
|
||
|
}
|
||
|
if($Escaped['admin_message']) {
|
||
|
//They did nothing of note, but still want to mark it (Or upload and mark)
|
||
|
$AdminComment .= " (".$Escaped['admin_message'].")";
|
||
|
}
|
||
|
if($AdminComment) {
|
||
|
$AdminComment = date("Y-m-d").' - '.$AdminComment."\n\n";
|
||
|
|
||
|
$DB->query("UPDATE users_info SET
|
||
|
AdminComment=CONCAT('".db_string($AdminComment)."',AdminComment)
|
||
|
WHERE UserID='".db_string($UploaderID)."'");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
//PM
|
||
|
if($Escaped['uploader_pm'] || $Warning > 0 || isset($Escaped['delete']) || $SendPM) {
|
||
|
if(isset($Escaped['delete'])) {
|
||
|
$PM = "[url=http://".NONSSL_SITE_URL."/torrents.php?torrentid=".$TorrentID."]Your above torrent[/url] was reported and has been deleted.\n\n";
|
||
|
} else {
|
||
|
$PM = "[url=http://".NONSSL_SITE_URL."/torrents.php?torrentid=".$TorrentID."]Your above torrent[/url] was reported but not deleted.\n\n";
|
||
|
}
|
||
|
|
||
|
$Preset = $ResolveType['resolve_options']['pm'];
|
||
|
|
||
|
if($Preset != "") {
|
||
|
$PM .= "Reason: ".$Preset;
|
||
|
}
|
||
|
|
||
|
if($Warning > 0) {
|
||
|
$PM .= "\nThis has resulted in a [url=http://".NONSSL_SITE_URL."/wiki.php?action=article&id=218]".$Warning." week warning.[/url]\n";
|
||
|
}
|
||
|
|
||
|
if($Upload) {
|
||
|
$PM .= "This has ".($Warning > 0 ? 'also ' : '')."resulted in you losing your upload privileges.";
|
||
|
}
|
||
|
|
||
|
if($Log) {
|
||
|
$PM = $PM."\nLog Message: ".$Log."\n";
|
||
|
}
|
||
|
|
||
|
if($Escaped['uploader_pm']) {
|
||
|
$PM .= "\nMessage from ".$LoggedUser['Username'].": ".$PMMessage;
|
||
|
}
|
||
|
|
||
|
$PM .= "\n\nReport was handled by ".$LoggedUser['Username'].".";
|
||
|
|
||
|
send_pm($UploaderID, 0, db_string($Escaped['raw_name']), db_string($PM));
|
||
|
}
|
||
|
|
||
|
$Cache->delete_value('reports_torrent_'.$TorrentID);
|
||
|
|
||
|
//Now we've done everything, update the DB with values
|
||
|
if($Report) {
|
||
|
$DB->query("UPDATE reportsv2 SET
|
||
|
Type = '".$Escaped['resolve_type']."',
|
||
|
LogMessage='".db_string($Log)."',
|
||
|
ModComment='".$Escaped['comment']."'
|
||
|
WHERE ID=".$ReportID);
|
||
|
}
|
||
|
} else {
|
||
|
//Someone beat us to it. Inform the staffer.
|
||
|
?>
|
||
|
<table cellpadding="5">
|
||
|
<tr>
|
||
|
<td>
|
||
|
<a href="reportsv2.php?view=report&id=<?=$ReportID?>">Somebody has already resolved this report</a>
|
||
|
<input type="button" value="Clear" onclick="ClearReport(<?=$ReportID?>);" />
|
||
|
</td>
|
||
|
</tr>
|
||
|
</table>
|
||
|
<?
|
||
|
}
|
||
|
?>
|