Gazelle/sections/collages/download.php

171 lines
6.3 KiB
PHP
Raw Normal View History

2011-03-28 14:21:28 +00:00
<?
2013-02-16 08:00:57 +00:00
/*
This page is something of a hack so those
easily scared off by funky solutions, don't
2011-03-28 14:21:28 +00:00
touch it! :P
2013-02-16 08:00:57 +00:00
There is a central problem to this page, it's
2011-03-28 14:21:28 +00:00
impossible to order before grouping in SQL, and
2013-02-16 08:00:57 +00:00
it's slow to run sub queries, so we had to get
2011-03-28 14:21:28 +00:00
creative for this one.
2013-02-16 08:00:57 +00:00
The solution I settled on abuses the way
$DB->to_array() works. What we've done, is
2011-03-28 14:21:28 +00:00
backwards ordering. The results returned by the
2013-02-16 08:00:57 +00:00
query have the best one for each GroupID last,
and while to_array traverses the results, it
2011-03-28 14:21:28 +00:00
overwrites the keys and leaves us with only the
2013-02-16 08:00:57 +00:00
desired result. This does mean however, that
the SQL has to be done in a somewhat backwards
2011-03-28 14:21:28 +00:00
fashion.
2013-02-16 08:00:57 +00:00
Thats all you get for a disclaimer, just
remember, this page isn't for the faint of
2011-03-28 14:21:28 +00:00
heart. -A9
SQL template:
2013-02-16 08:00:57 +00:00
SELECT
CASE
WHEN t.Format='MP3' AND t.Encoding='V0 (VBR)' THEN 1
WHEN t.Format='MP3' AND t.Encoding='V2 (VBR)' THEN 2
ELSE 100
END AS Rank,
2011-03-28 14:21:28 +00:00
t.GroupID,
t.Media,
t.Format,
t.Encoding,
IF(t.Year=0,tg.Year,t.Year),
tg.Name,
a.Name,
t.Size
2013-02-16 08:00:57 +00:00
FROM torrents AS t
2011-03-28 14:21:28 +00:00
INNER JOIN collages_torrents AS c ON t.GroupID=c.GroupID AND c.CollageID='8'
INNER JOIN torrents_group AS tg ON tg.ID=t.GroupID AND tg.CategoryID='1'
LEFT JOIN artists_group AS a ON a.ArtistID=tg.ArtistID
LEFT JOIN torrents_files AS f ON t.ID=f.TorrentID
ORDER BY t.GroupID ASC, Rank DESC, t.Seeders ASC
*/
2013-02-21 08:00:30 +00:00
if (
2013-02-16 08:00:57 +00:00
!isset($_REQUEST['collageid']) ||
!isset($_REQUEST['preference']) ||
!is_number($_REQUEST['preference']) ||
!is_number($_REQUEST['collageid']) ||
2011-03-28 14:21:28 +00:00
$_REQUEST['preference'] > 2 ||
count($_REQUEST['list']) == 0
2013-02-21 08:00:30 +00:00
) {
error(0);
}
if (!check_perms('zip_downloader')) {
error(403);
}
2011-03-28 14:21:28 +00:00
2013-02-21 08:00:30 +00:00
require(SERVER_ROOT.'/classes/class_bencode.php');
require(SERVER_ROOT.'/classes/class_torrent.php');
2011-03-28 14:21:28 +00:00
2013-02-21 08:00:30 +00:00
$Preferences = array('RemasterTitle DESC', 'Seeders ASC', 'Size ASC');
2011-03-28 14:21:28 +00:00
$CollageID = $_REQUEST['collageid'];
$Preference = $Preferences[$_REQUEST['preference']];
$DB->query("SELECT Name FROM collages WHERE ID='$CollageID'");
2013-02-21 08:00:30 +00:00
list($CollageName) = $DB->next_record(MYSQLI_NUM, false);
2011-03-28 14:21:28 +00:00
$SQL = "SELECT CASE ";
foreach ($_REQUEST['list'] as $Priority => $Selection) {
2013-02-21 08:00:30 +00:00
if (!is_number($Priority)) {
2011-11-07 08:00:19 +00:00
continue;
}
2011-03-28 14:21:28 +00:00
$SQL .= "WHEN ";
switch ($Selection) {
case '00': $SQL .= "t.Format='MP3' AND t.Encoding='V0 (VBR)'"; break;
case '01': $SQL .= "t.Format='MP3' AND t.Encoding='APX (VBR)'"; break;
case '02': $SQL .= "t.Format='MP3' AND t.Encoding='256 (VBR)'"; break;
case '03': $SQL .= "t.Format='MP3' AND t.Encoding='V1 (VBR)'"; break;
case '10': $SQL .= "t.Format='MP3' AND t.Encoding='224 (VBR)'"; break;
case '11': $SQL .= "t.Format='MP3' AND t.Encoding='V2 (VBR)'"; break;
case '12': $SQL .= "t.Format='MP3' AND t.Encoding='APS (VBR)'"; break;
case '13': $SQL .= "t.Format='MP3' AND t.Encoding='192 (VBR)'"; break;
case '20': $SQL .= "t.Format='MP3' AND t.Encoding='320'"; break;
case '21': $SQL .= "t.Format='MP3' AND t.Encoding='256'"; break;
case '22': $SQL .= "t.Format='MP3' AND t.Encoding='224'"; break;
case '23': $SQL .= "t.Format='MP3' AND t.Encoding='192'"; break;
case '30': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='Vinyl'"; break;
case '31': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='DVD'"; break;
case '32': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='SACD'"; break;
2011-12-02 08:00:15 +00:00
case '33': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='WEB'"; break;
case '34': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless' AND HasLog='1' AND LogScore='100' AND HasCue='1'"; break;
case '35': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless' AND HasLog='1' AND LogScore='100'"; break;
case '36': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless' AND HasLog='1'"; break;
case '37': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless'"; break;
2011-03-28 14:21:28 +00:00
case '40': $SQL .= "t.Format='DTS'"; break;
case '42': $SQL .= "t.Format='AAC' AND t.Encoding='320'"; break;
case '43': $SQL .= "t.Format='AAC' AND t.Encoding='256'"; break;
case '44': $SQL .= "t.Format='AAC' AND t.Encoding='q5.5'"; break;
case '45': $SQL .= "t.Format='AAC' AND t.Encoding='q5'"; break;
case '46': $SQL .= "t.Format='AAC' AND t.Encoding='192'"; break;
default: error(0);
}
$SQL .= " THEN $Priority ";
}
$SQL .= "ELSE 100 END AS Rank,
t.GroupID,
2013-02-21 08:00:30 +00:00
t.ID AS TorrentID,
2011-03-28 14:21:28 +00:00
t.Media,
t.Format,
t.Encoding,
2013-02-21 08:00:30 +00:00
IF(t.RemasterYear=0,tg.Year,t.RemasterYear) AS Year,
2011-03-28 14:21:28 +00:00
tg.Name,
2011-11-06 08:00:31 +00:00
t.Size
2013-02-16 08:00:57 +00:00
FROM torrents AS t
2011-03-28 14:21:28 +00:00
INNER JOIN collages_torrents AS c ON t.GroupID=c.GroupID AND c.CollageID='$CollageID'
INNER JOIN torrents_group AS tg ON tg.ID=t.GroupID AND tg.CategoryID='1'
ORDER BY t.GroupID ASC, Rank DESC, t.$Preference";
2013-02-21 08:00:30 +00:00
$DownloadsQ = $DB->query($SQL);
$Collector = new TorrentsDL($DownloadsQ, $CollageName);
while (list($Downloads, $GroupIDs) = $Collector->get_downloads('GroupID')) {
$Artists = Artists::get_artists($GroupIDs);
$TorrentFilesQ = $DB->query("SELECT TorrentID, File FROM torrents_files WHERE TorrentID IN (".implode(',', array_keys($GroupIDs)).")", false);
if (is_int($TorrentFilesQ)) {
// Query failed. Let's not create a broken zip archive
foreach ($GroupIDs as $GroupID) {
$Download =& $Downloads[$GroupID];
$Download['Artist'] = Artists::display_artists($Artists[$GroupID], false, true, false);
$Collector->fail_file($Download);
}
2011-03-28 14:21:28 +00:00
continue;
}
2013-02-21 08:00:30 +00:00
while (list($TorrentID, $TorrentFile) = $DB->next_record(MYSQLI_NUM, false)) {
$GroupID = $GroupIDs[$TorrentID];
$Download =& $Downloads[$GroupID];
$Download['Artist'] = Artists::display_artists($Artists[$Download['GroupID']], false, true, false);
if ($Download['Rank'] == 100) {
$Collector->skip_file($Download);
continue;
}
if (Misc::is_new_torrent($TorrentFile)) {
$TorEnc = BEncTorrent::add_announce_url($TorrentFile, ANNOUNCE_URL."/$LoggedUser[torrent_pass]/announce");
} else {
$Contents = unserialize(base64_decode($TorrentFile));
$Tor = new TORRENT($Contents, true);
$Tor->set_announce_url(ANNOUNCE_URL."/$LoggedUser[torrent_pass]/announce");
unset($Tor->Val['announce-list']);
$TorEnc = $Tor->enc();
}
$Collector->add_file($TorEnc, $Download);
unset($Download);
2012-02-28 08:00:21 +00:00
}
2011-03-28 14:21:28 +00:00
}
2013-02-21 08:00:30 +00:00
$Collector->finalize();
$Settings = array(implode(':', $_REQUEST['list']), $_REQUEST['preference']);
if (!isset($LoggedUser['Collector']) || $LoggedUser['Collector'] != $Settings) {
Users::update_site_options($LoggedUser['ID'], array('Collector' => $Settings));
2011-03-28 14:21:28 +00:00
}
2012-08-25 08:00:15 +00:00
define('IE_WORKAROUND_NO_CACHE_HEADERS', 1);
2011-03-28 14:21:28 +00:00
?>