mirror of
https://github.com/WhatCD/Gazelle.git
synced 2024-12-13 10:56:26 +00:00
309 lines
14 KiB
PHP
309 lines
14 KiB
PHP
<?
|
|
$TorrentID = $_GET['torrentid'];
|
|
if (!$TorrentID || !is_number($TorrentID)) {
|
|
error(404);
|
|
}
|
|
|
|
|
|
$DB->query("
|
|
SELECT
|
|
t.UserID,
|
|
t.Time,
|
|
COUNT(x.uid)
|
|
FROM torrents AS t
|
|
LEFT JOIN xbt_snatched AS x ON x.fid = t.ID
|
|
WHERE t.ID = $TorrentID
|
|
GROUP BY t.UserID");
|
|
|
|
if (!$DB->has_results()) {
|
|
error('Torrent already deleted.');
|
|
}
|
|
|
|
if ($Cache->get_value('torrent_'.$TorrentID.'_lock')) {
|
|
error('Torrent cannot be deleted because the upload process is not completed yet. Please try again later.');
|
|
}
|
|
|
|
|
|
list($UserID, $Time, $Snatches) = $DB->next_record();
|
|
|
|
|
|
if ($LoggedUser['ID'] != $UserID && !check_perms('torrents_delete')) {
|
|
error(403);
|
|
}
|
|
|
|
if (isset($_SESSION['logged_user']['multi_delete']) && $_SESSION['logged_user']['multi_delete'] >= 3 && !check_perms('torrents_delete_fast')) {
|
|
error('You have recently deleted 3 torrents. Please contact a staff member if you need to delete more.');
|
|
}
|
|
|
|
if (time_ago($Time) > 3600 * 24 * 7 && !check_perms('torrents_delete')) { // Should this be torrents_delete or torrents_delete_fast?
|
|
error('You can no longer delete this torrent as it has been uploaded for over a week. If you now think there is a problem, please report the torrent instead.');
|
|
}
|
|
|
|
if ($Snatches > 4 && !check_perms('torrents_delete')) { // Should this be torrents_delete or torrents_delete_fast?
|
|
error('You can no longer delete this torrent as it has been snatched by 5 or more users. If you believe there is a problem with this torrent, please report it instead.');
|
|
}
|
|
|
|
|
|
View::show_header('Delete torrent', 'reportsv2');
|
|
?>
|
|
<div class="thin center">
|
|
<div class="box" style="width: 600px; margin: 0px auto;">
|
|
<div class="head colhead">
|
|
Delete torrent
|
|
</div>
|
|
<div class="pad">
|
|
<form class="delete_form" name="torrent" action="torrents.php" method="post">
|
|
<input type="hidden" name="action" value="takedelete" />
|
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
|
<input type="hidden" name="torrentid" value="<?=$TorrentID?>" />
|
|
<strong>Reason: </strong>
|
|
<select name="reason">
|
|
<option value="Dead">Dead</option>
|
|
<option value="Dupe">Dupe</option>
|
|
<option value="Trumped">Trumped</option>
|
|
<option value="Rules Broken">Rules broken</option>
|
|
<option value="" selected="selected">Other</option>
|
|
</select>
|
|
|
|
<strong>Extra info: </strong>
|
|
<input type="text" name="extra" size="30" />
|
|
<input value="Delete" type="submit" />
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?
|
|
if (check_perms('admin_reports')) {
|
|
?>
|
|
<div id="all_reports" style="width: 80%; margin-left: auto; margin-right: auto;">
|
|
<?
|
|
include(SERVER_ROOT.'/classes/reports.class.php');
|
|
|
|
require(SERVER_ROOT.'/sections/reportsv2/array.php');
|
|
require(SERVER_ROOT.'/classes/text.class.php');
|
|
$Text = NEW TEXT;
|
|
$ReportID = 0;
|
|
$DB->query("
|
|
SELECT
|
|
tg.Name,
|
|
tg.ID,
|
|
CASE COUNT(ta.GroupID)
|
|
WHEN 1 THEN aa.ArtistID
|
|
WHEN 0 THEN '0'
|
|
ELSE '0'
|
|
END AS ArtistID,
|
|
CASE COUNT(ta.GroupID)
|
|
WHEN 1 THEN aa.Name
|
|
WHEN 0 THEN ''
|
|
ELSE 'Various Artists'
|
|
END AS ArtistName,
|
|
tg.Year,
|
|
tg.CategoryID,
|
|
t.Time,
|
|
t.Remastered,
|
|
t.RemasterTitle,
|
|
t.RemasterYear,
|
|
t.Media,
|
|
t.Format,
|
|
t.Encoding,
|
|
t.Size,
|
|
t.HasLog,
|
|
t.LogScore,
|
|
t.UserID AS UploaderID,
|
|
uploader.Username
|
|
FROM torrents AS t
|
|
LEFT JOIN torrents_group AS tg ON tg.ID = t.GroupID
|
|
LEFT JOIN torrents_artists AS ta ON ta.GroupID = tg.ID AND ta.Importance = '1'
|
|
LEFT JOIN artists_alias AS aa ON aa.AliasID = ta.AliasID
|
|
LEFT JOIN users_main AS uploader ON uploader.ID = t.UserID
|
|
WHERE t.ID = $TorrentID");
|
|
|
|
if (!$DB->has_results()) {
|
|
die();
|
|
}
|
|
list($GroupName, $GroupID, $ArtistID, $ArtistName, $Year, $CategoryID, $Time, $Remastered, $RemasterTitle,
|
|
$RemasterYear, $Media, $Format, $Encoding, $Size, $HasLog, $LogScore, $UploaderID, $UploaderName) = $DB->next_record();
|
|
|
|
$Type = 'dupe'; //hardcoded default
|
|
|
|
if (array_key_exists($Type, $Types[$CategoryID])) {
|
|
$ReportType = $Types[$CategoryID][$Type];
|
|
} elseif (array_key_exists($Type,$Types['master'])) {
|
|
$ReportType = $Types['master'][$Type];
|
|
} else {
|
|
//There was a type but it wasn't an option!
|
|
$Type = 'other';
|
|
$ReportType = $Types['master']['other'];
|
|
}
|
|
$RemasterDisplayString = Reports::format_reports_remaster_info($Remastered, $RemasterTitle, $RemasterYear);
|
|
|
|
if ($ArtistID == 0 && empty($ArtistName)) {
|
|
$RawName = $GroupName.($Year ? " ($Year)" : '').($Format || $Encoding || $Media ? " [$Format/$Encoding/$Media]" : '') . $RemasterDisplayString . ($HasLog ? " ({$LogScore}%)" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
$LinkName = "<a href=\"torrents.php?id=$GroupID\">$GroupName".($Year ? " ($Year)" : '')."</a> <a href=\"torrents.php?torrentid=$TorrentID\">".($Format || $Encoding || $Media ? " [$Format/$Encoding/$Media]" : '') . "$RemasterDisplayString</a>" . ($HasLog ? " <a href=\"torrents.php?action=viewlog&torrentid=$TorrentID&groupid=$GroupID\">(Log: {$LogScore}%)</a>" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
$BBName = "[url=torrents.php?id=$GroupID]$GroupName".($Year ? " ($Year)" : '')."[/url] [url=torrents.php?torrentid=$TorrentID][$Format/$Encoding/$Media]{$RemasterDisplayString}[/url] " . ($HasLog ? " [url=torrents.php?action=viewlog&torrentid=$TorrentID&groupid=$GroupID](Log: {$LogScore}%)[/url]" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
} elseif ($ArtistID == 0 && $ArtistName == 'Various Artists') {
|
|
$RawName = "Various Artists - $GroupName".($Year ? " ($Year)" : '')." [$Format/$Encoding/$Media]$RemasterDisplayString" . ($HasLog ? " ({$LogScore}%)" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
$LinkName = "Various Artists - <a href=\"torrents.php?id=$GroupID\">$GroupName".($Year ? " ($Year)" : '')."</a> <a href=\"torrents.php?torrentid=$TorrentID\"> [$Format/$Encoding/$Media]$RemasterDisplayString</a> ".($HasLog ? " <a href=\"torrents.php?action=viewlog&torrentid=$TorrentID&groupid=$GroupID\">(Log: {$LogScore}%)</a>" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
$BBName = "Various Artists - [url=torrents.php?id=$GroupID]$GroupName".($Year ? " ($Year)" : '')."[/url] [url=torrents.php?torrentid=$TorrentID][$Format/$Encoding/$Media]{$RemasterDisplayString}[/url] ".($HasLog ? " [url=torrents.php?action=viewlog&torrentid=$TorrentID&groupid=$GroupID](Log: {$LogScore}%)[/url]" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
} else {
|
|
$RawName = "$ArtistName - $GroupName".($Year ? " ($Year)" : '')." [$Format/$Encoding/$Media]$RemasterDisplayString" . ($HasLog ? " ({$LogScore}%)" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
$LinkName = "<a href=\"artist.php?id=$ArtistID\">$ArtistName</a> - <a href=\"torrents.php?id=$GroupID\">$GroupName".($Year ? " ($Year)" : '')."</a> <a href=\"torrents.php?torrentid=$TorrentID\"> [$Format/$Encoding/$Media]$RemasterDisplayString</a> ".($HasLog ? " <a href=\"torrents.php?action=viewlog&torrentid=$TorrentID&groupid=$GroupID\">(Log: {$LogScore}%)</a>" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
$BBName = "[url=artist.php?id=$ArtistID]".$ArtistName."[/url] - [url=torrents.php?id=$GroupID]$GroupName".($Year ? " ($Year)" : '')."[/url] [url=torrents.php?torrentid=$TorrentID][$Format/$Encoding/$Media]{$RemasterDisplayString}[/url] " . ($HasLog ? " [url=torrents.php?action=viewlog&torrentid=$TorrentID&groupid=$GroupID](Log: {$LogScore}%)[/url]" : '').' ('.number_format($Size / (1024 * 1024), 2).' MB)';
|
|
}
|
|
?>
|
|
<div id="report<?=$ReportID?>">
|
|
<form class="create_form" name="report" id="reportform_<?=$ReportID?>" action="reports.php" method="post">
|
|
<?
|
|
/*
|
|
* Some of these are for takeresolve, some for the JavaScript.
|
|
*/
|
|
?>
|
|
<div>
|
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
|
<input type="hidden" id="newreportid" name="newreportid" value="<?=$ReportID?>" />
|
|
<input type="hidden" id="reportid<?=$ReportID?>" name="reportid" value="<?=$ReportID?>" />
|
|
<input type="hidden" id="torrentid<?=$ReportID?>" name="torrentid" value="<?=$TorrentID?>" />
|
|
<input type="hidden" id="uploader<?=$ReportID?>" name="uploader" value="<?=$UploaderName?>" />
|
|
<input type="hidden" id="uploaderid<?=$ReportID?>" name="uploaderid" value="<?=$UploaderID?>" />
|
|
<input type="hidden" id="reporterid<?=$ReportID?>" name="reporterid" value="<?=$ReporterID?>" />
|
|
<input type="hidden" id="raw_name<?=$ReportID?>" name="raw_name" value="<?=$RawName?>" />
|
|
<input type="hidden" id="type<?=$ReportID?>" name="type" value="<?=$Type?>" />
|
|
<input type="hidden" id="categoryid<?=$ReportID?>" name="categoryid" value="<?=$CategoryID?>" />
|
|
<input type="hidden" id="pm_type<?=$ReportID?>" name="pm_type" value="Uploader" />
|
|
<input type="hidden" id="from_delete<?=$ReportID?>" name="from_delete" value="<?=$GroupID?>" />
|
|
</div>
|
|
<table cellpadding="5" class="layout">
|
|
<tr>
|
|
<td class="label">Torrent:</td>
|
|
<td colspan="3">
|
|
<? if (!$GroupID) { ?>
|
|
<a href="log.php?search=Torrent+<?=$TorrentID?>"><?=$TorrentID?></a> (Deleted)
|
|
<? } else { ?>
|
|
<?=$LinkName?>
|
|
<a href="torrents.php?action=download&id=<?=$TorrentID?>&authkey=<?=$LoggedUser['AuthKey']?>&torrent_pass=<?=$LoggedUser['torrent_pass']?>" class="brackets" title="Download">DL</a>
|
|
uploaded by <a href="user.php?id=<?=$UploaderID?>"><?=$UploaderName?></a> <?=time_diff($Time)?>
|
|
<br />
|
|
<? $DB->query("
|
|
SELECT r.ID
|
|
FROM reportsv2 AS r
|
|
LEFT JOIN torrents AS t ON t.ID = r.TorrentID
|
|
WHERE r.Status != 'Resolved'
|
|
AND t.GroupID = $GroupID");
|
|
$GroupOthers = ($DB->has_results());
|
|
|
|
if ($GroupOthers > 0) { ?>
|
|
<div style="text-align: right;">
|
|
<a href="reportsv2.php?view=group&id=<?=$GroupID?>">There <?=(($GroupOthers > 1) ? "are $GroupOthers reports" : "is 1 other report")?> for torrent(s) in this group</a>
|
|
</div>
|
|
<? }
|
|
|
|
$DB->query("
|
|
SELECT t.UserID
|
|
FROM reportsv2 AS r
|
|
JOIN torrents AS t ON t.ID = r.TorrentID
|
|
WHERE r.Status != 'Resolved'
|
|
AND t.UserID = $UploaderID");
|
|
$UploaderOthers = ($DB->has_results());
|
|
|
|
if ($UploaderOthers > 0) { ?>
|
|
<div style="text-align: right;">
|
|
<a href="reportsv2.php?view=uploader&id=<?=$UploaderID?>">There <?=(($UploaderOthers > 1) ? "are $UploaderOthers reports" : "is 1 other report")?> for torrent(s) uploaded by this user</a>
|
|
</div>
|
|
<? }
|
|
|
|
$DB->query("
|
|
SELECT DISTINCT req.ID,
|
|
req.FillerID,
|
|
um.Username,
|
|
req.TimeFilled
|
|
FROM requests AS req
|
|
JOIN users_main AS um ON um.ID = req.FillerID
|
|
AND req.TorrentID = $TorrentID");
|
|
$Requests = ($DB->has_results());
|
|
if ($Requests > 0) {
|
|
while (list($RequestID, $FillerID, $FillerName, $FilledTime) = $DB->next_record()) {
|
|
?>
|
|
<div style="text-align: right;">
|
|
<strong class="important_text"><a href="user.php?id=<?=$FillerID?>"><?=$FillerName?></a> used this torrent to fill <a href="requests.php?action=viewrequest&id=<?=$RequestID?>">this request</a> <?=time_diff($FilledTime)?></strong>
|
|
</div>
|
|
<? }
|
|
}
|
|
}
|
|
?>
|
|
</td>
|
|
</tr>
|
|
<? // END REPORTED STUFF :|: BEGIN MOD STUFF ?>
|
|
<tr>
|
|
<td class="label">
|
|
<a href="javascript:Load('<?=$ReportID?>')" title="Click here to reset the resolution options to their default values.">Resolve:</a>
|
|
</td>
|
|
<td colspan="3">
|
|
<select name="resolve_type" id="resolve_type<?=$ReportID?>" onchange="ChangeResolve(<?=$ReportID?>);">
|
|
<?
|
|
$TypeList = $Types['master'] + $Types[$CategoryID];
|
|
$Priorities = array();
|
|
foreach ($TypeList as $Key => $Value) {
|
|
$Priorities[$Key] = $Value['priority'];
|
|
}
|
|
array_multisort($Priorities, SORT_ASC, $TypeList);
|
|
|
|
foreach ($TypeList as $IType => $Data) {
|
|
?>
|
|
<option value="<?=$IType?>"<?=(($Type == $IType) ? ' selected="selected"' : '')?>><?=$Data['title']?></option>
|
|
<?
|
|
}
|
|
?>
|
|
</select>
|
|
<span id="options<?=$ReportID?>">
|
|
<span class="tooltip" title="Delete torrent?">
|
|
<strong>Delete</strong>
|
|
<input type="checkbox" name="delete" id="delete<?=$ReportID?>"<?=($ReportType['resolve_options']['delete'] ? ' checked="checked"' : '')?> />
|
|
</span>
|
|
<span class="tooltip" title="Warning length in weeks">
|
|
<strong>Warning</strong>
|
|
<select name="warning" id="warning<?=$ReportID?>">
|
|
<? for ($i = 0; $i < 9; $i++) { ?>
|
|
<option value="<?=$i?>"<?=(($ReportType['resolve_options']['warn'] == $i) ? ' selected="selected"' : '')?>><?=$i?></option>
|
|
<? } ?>
|
|
</select>
|
|
</span>
|
|
<span class="tooltip" title="Remove upload privileges?">
|
|
<strong>Upload</strong>
|
|
<input type="checkbox" name="upload" id="upload<?=$ReportID?>"<?=($ReportType['resolve_options']['upload'] ? ' checked="checked"' : '')?> />
|
|
</span>
|
|
</span>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">PM uploader:</td>
|
|
<td colspan="3">
|
|
<span class="tooltip" title="Appended to the regular message unless using "Send Now".">
|
|
<textarea name="uploader_pm" id="uploader_pm<?=$ReportID?>" cols="50" rows="1"></textarea>
|
|
</span>
|
|
<input type="button" value="Send Now" onclick="SendPM(<?=$ReportID?>);" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label"><strong>Extra</strong> log message:</td>
|
|
<td>
|
|
<input type="text" name="log_message" id="log_message<?=$ReportID?>" size="40" />
|
|
</td>
|
|
<td class="label"><strong>Extra</strong> staff notes:</td>
|
|
<td>
|
|
<input type="text" name="admin_message" id="admin_message<?=$ReportID?>" size="40" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="4" style="text-align: center;">
|
|
<input type="button" value="Submit" onclick="TakeResolve(<?=$ReportID?>);" />
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</form>
|
|
<br />
|
|
</div>
|
|
</div>
|
|
<?
|
|
}
|
|
View::show_footer(); ?>
|