Gazelle/sections/better/snatch.php

235 lines
8.0 KiB
PHP
Raw Normal View History

2011-03-28 14:21:28 +00:00
<?
2012-11-06 08:00:20 +00:00
if (!empty($_GET['userid']) && is_number($_GET['userid'])) {
2011-03-28 14:21:28 +00:00
if (check_perms('users_override_paranoia')) {
$UserID = $_GET['userid'];
} else {
error(403);
}
} else {
$UserID = $LoggedUser['ID'];
}
2012-11-06 08:00:20 +00:00
$Encodings = array('V0 (VBR)', 'V2 (VBR)', '320');
$EncodingKeys = array_fill_keys($Encodings, true);
if (!empty($_GET['filter']) && $_GET['filter'] == 'seeding') {
$SeedingOnly = true;
} else {
$SeedingOnly = false;
}
2011-03-28 14:21:28 +00:00
// Get list of FLAC snatches
$DB->query("SELECT t.GroupID, x.fid
FROM ".($SeedingOnly ? 'xbt_files_users' : 'xbt_snatched')." AS x
JOIN torrents AS t ON t.ID=x.fid
2013-02-13 08:00:35 +00:00
WHERE t.Format='FLAC'
AND ((t.LogScore = '100' AND t.Media = 'CD')
2013-02-17 08:00:08 +00:00
OR t.Media != 'CD')
AND x.uid='$UserID'");
2011-03-28 14:21:28 +00:00
2012-11-06 08:00:20 +00:00
$SnatchedTorrentIDs = array_fill_keys($DB->collect('fid'), true);
$SnatchedGroupIDs = array_unique($DB->collect('GroupID'));
if (count($SnatchedGroupIDs) > 1000) {
shuffle($SnatchedGroupIDs);
$SnatchedGroupIDs = array_slice($SnatchedGroupIDs, 0, 1000);
}
2011-03-28 14:21:28 +00:00
2012-11-06 08:00:20 +00:00
if (count($SnatchedGroupIDs) == 0) {
2013-02-17 08:00:08 +00:00
error(($SeedingOnly ? "You aren't seeding any perfect FLACs!" : "You haven't snatched any perfect FLACs!"));
2012-11-06 08:00:20 +00:00
}
2011-03-28 14:21:28 +00:00
// Create hash table
$DB->query("CREATE TEMPORARY TABLE temp_sections_better_snatch
2011-03-28 14:21:28 +00:00
SELECT t.GroupID,
2012-11-06 08:00:20 +00:00
GROUP_CONCAT(t.Encoding SEPARATOR ' ') AS EncodingList,
CRC32(CONCAT_WS(' ', Media, Remasteryear, Remastertitle,
Remasterrecordlabel, Remastercataloguenumber)) AS RemIdent
2011-03-28 14:21:28 +00:00
FROM torrents AS t
WHERE t.GroupID IN(".implode(',',$SnatchedGroupIDs).")
2012-11-06 08:00:20 +00:00
GROUP BY t.GroupID, RemIdent");
2011-03-28 14:21:28 +00:00
//$DB->query('SELECT * FROM t');
$DB->query("SELECT GroupID FROM temp_sections_better_snatch
2013-02-13 08:00:35 +00:00
WHERE EncodingList NOT LIKE '%V0 (VBR)%'
OR EncodingList NOT LIKE '%V2 (VBR)%'
2011-03-28 14:21:28 +00:00
OR EncodingList NOT LIKE '%320%'");
2012-11-06 08:00:20 +00:00
$GroupIDs = array_fill_keys($DB->collect('GroupID'), true);
2011-03-28 14:21:28 +00:00
2012-11-06 08:00:20 +00:00
if (count($GroupIDs) == 0) {
error('No results found');
}
$Groups = Torrents::get_groups(array_keys($GroupIDs));
$Groups = $Groups['matches'];
2011-03-28 14:21:28 +00:00
2012-11-06 08:00:20 +00:00
$TorrentGroups = array();
foreach ($Groups as $GroupID => $Group) {
if (empty($Group['Torrents'])) {
unset($Groups[$GroupID]);
continue;
}
foreach ($Group['Torrents'] as $Torrent) {
$TorRemIdent = "$Torrent[Media] $Torrent[RemasterYear] $Torrent[RemasterTitle] $Torrent[RemasterRecordLabel] $Torrent[RemasterCatalogueNumber]";
if (!isset($TorrentGroups[$Group['ID']])) {
$TorrentGroups[$Group['ID']] = array(
$TorRemIdent => array(
'FlacID' => 0,
'Formats' => array(),
2012-12-06 08:00:17 +00:00
'IsSnatched' => $Torrent['IsSnatched'],
2012-11-06 08:00:20 +00:00
'Medium' => $Torrent['Media'],
'RemasterTitle' => $Torrent['RemasterTitle'],
'RemasterYear' => $Torrent['RemasterYear'],
'RemasterRecordLabel' => $Torrent['RemasterRecordLabel'],
'RemasterCatalogueNumber' => $Torrent['RemasterCatalogueNumber']
)
);
} elseif (!isset($TorrentGroups[$Group['ID']][$TorRemIdent])) {
$TorrentGroups[$Group['ID']][$TorRemIdent] = array(
'FlacID' => 0,
'Formats' => array(),
2012-12-06 08:00:17 +00:00
'IsSnatched' => $Torrent['IsSnatched'],
2012-11-06 08:00:20 +00:00
'Medium' => $Torrent['Media'],
'RemasterTitle' => $Torrent['RemasterTitle'],
'RemasterYear' => $Torrent['RemasterYear'],
'RemasterRecordLabel' => $Torrent['RemasterRecordLabel'],
'RemasterCatalogueNumber' => $Torrent['RemasterCatalogueNumber']
);
}
if (isset($EncodingKeys[$Torrent['Encoding']])) {
$TorrentGroups[$Group['ID']][$TorRemIdent]['Formats'][$Torrent['Encoding']] = true;
} elseif (isset($SnatchedTorrentIDs[$Torrent['ID']])) {
$TorrentGroups[$Group['ID']][$TorRemIdent]['FlacID'] = $Torrent['ID'];
}
}
}
2013-02-17 08:00:08 +00:00
// count how many FLAC torrents we have in this list totally (key 'total')
// how many transcodes there are missing totally (key 'miss_total')
// and for each format (keys , 'miss_V0 (VBR)', 'miss_V2 (VBR)', 'miss_320')
// the latter happens by counting the number of existing transcodes and then subtracting because that's easier
$Counter = array();
$Counter['total'] = 0;
foreach($TorrentGroups as $Editions) {
foreach($Editions as $Edition) {
if($Edition['FlacID'] == 0) { continue; } // no FLAC in this edition
$edition_miss = 0; //number of transcodes missing in this edition
foreach($Encodings as $Encoding) {
if(!isset($Edition['Formats'][$Encoding])) {
++$edition_miss;
++$Counter['miss_'.$Encoding];
}
}
$Counter['miss_total'] += $edition_miss;
$Counter['total'] += (bool)$edition_miss;
}
}
2011-03-28 14:21:28 +00:00
2012-10-11 08:00:15 +00:00
View::show_header('Transcode Snatches');
2011-03-28 14:21:28 +00:00
?>
<div class="linkbox">
2012-11-06 08:00:20 +00:00
<? if ($SeedingOnly) { ?>
2013-02-13 08:00:35 +00:00
<a href="better.php?method=snatch" class="brackets">Show all</a>
<? } else { ?>
2013-02-13 08:00:35 +00:00
<a href="better.php?method=snatch&amp;filter=seeding" class="brackets">Just those currently seeding</a>
<? } ?>
</div>
2011-03-28 14:21:28 +00:00
<div class="thin">
2013-02-17 08:00:08 +00:00
<h2>Transcode <?=($SeedingOnly ? 'seeding' : 'snatched')?> torrents</h2>
<h3>Stats</h3>
<div class="box pad">
<p>
Number of perfect FLACs you can transcode: <?=$Counter['total']?><br />
Number of missing transcodes: <?=$Counter['miss_total']?><br />
Number of missing V2 / V0 / 320 transcodes: <?=$Counter['miss_V2 (VBR)']?> / <?=$Counter['miss_V0 (VBR)']?> / <?=$Counter['miss_320']?>
</p>
</div>
<h3>List</h3>
2012-09-01 08:00:24 +00:00
<table width="100%" class="torrent_table">
2011-03-28 14:21:28 +00:00
<tr class="colhead">
<td>Torrent</td>
<td>V2</td>
<td>V0</td>
<td>320</td>
</tr>
<?
2012-11-06 08:00:20 +00:00
foreach ($TorrentGroups as $GroupID => $Editions) {
$GroupInfo = $Groups[$GroupID];
$GroupYear = $GroupInfo['Year'];
$ExtendedArtists = $GroupInfo['ExtendedArtists'];
$GroupCatalogueNumber = $GroupInfo['CatalogueNumber'];
$GroupName = $GroupInfo['Name'];
$GroupRecordLabel = $GroupInfo['RecordLabel'];
$ReleaseType = $GroupInfo['ReleaseType'];
if (!empty($ExtendedArtists[1]) || !empty($ExtendedArtists[4]) || !empty($ExtendedArtists[5]) || !empty($ExtendedArtists[6])) {
unset($ExtendedArtists[2]);
unset($ExtendedArtists[3]);
$ArtistNames = Artists::display_artists($ExtendedArtists);
} else {
$ArtistNames = '';
2011-03-28 14:21:28 +00:00
}
2012-11-06 08:00:20 +00:00
$TagList = array();
$TagList = explode(' ', str_replace('_', '.', $GroupInfo['TagList']));
$TorrentTags = array();
foreach ($TagList as $Tag) {
$TorrentTags[] = '<a href="torrents.php?taglist='.$Tag.'">'.$Tag.'</a>';
2011-03-28 14:21:28 +00:00
}
2012-11-06 08:00:20 +00:00
$TorrentTags = implode(', ', $TorrentTags);
foreach ($Editions as $RemIdent => $Edition) {
if (!$Edition['FlacID'] || count($Edition['Formats']) == 3) {
continue;
2012-02-05 08:00:20 +00:00
}
2012-11-06 08:00:20 +00:00
$DisplayName = $ArtistNames . '<a href="torrents.php?id='.$GroupID.'&amp;torrentid='.$Edition['FlacID'].'#torrent'.$Edition['FlacID'].'" title="View Torrent">'.$GroupName.'</a>';
if($GroupYear > 0) {
$DisplayName .= " [".$GroupYear."]";
}
if ($ReleaseType > 0) {
$DisplayName .= " [".$ReleaseTypes[$ReleaseType]."]";
}
$DisplayName .= ' ['.$Edition['Medium'].']';
$EditionInfo = array();
if (!empty($Edition['RemasterYear'])) {
$ExtraInfo = $Edition['RemasterYear'];
} else {
$ExtraInfo = '';
}
if (!empty($Edition['RemasterRecordLabel'])) {
$EditionInfo[] = $Edition['RemasterRecordLabel'];
}
if (!empty($Edition['RemasterTitle'])) {
$EditionInfo[] = $Edition['RemasterTitle'];
}
if (!empty($Edition['RemasterCatalogueNumber'])) {
$EditionInfo[] = $Edition['RemasterCatalogueNumber'];
}
if (!empty($Edition['RemasterYear'])) {
$ExtraInfo .= ' - ';
}
$ExtraInfo .= implode(' / ', $EditionInfo);
2011-03-28 14:21:28 +00:00
?>
2012-12-06 08:00:17 +00:00
<tr class="torrent torrent_row<?=$Edition['IsSnatched'] ? ' snatched_torrent' : ''?>">
2011-03-28 14:21:28 +00:00
<td>
2012-11-06 08:00:20 +00:00
<span class="torrent_links_block">
2013-02-13 08:00:35 +00:00
<a href="torrents.php?action=download&amp;id=<?=$Edition['FlacID']?>&amp;authkey=<?=$LoggedUser['AuthKey']?>&amp;torrent_pass=<?=$LoggedUser['torrent_pass']?>" title="Download" class="brackets">DL</a>
2012-11-06 08:00:20 +00:00
</span>
<?=$DisplayName?>
<div class="torrent_info"><?=$ExtraInfo?></div>
<div class="tags"><?=$TorrentTags?></div>
2011-03-28 14:21:28 +00:00
</td>
2012-11-06 08:00:20 +00:00
<td><?=isset($Edition['Formats']['V2 (VBR)'])?'<strong class="important_text_alt">YES</strong>':'<strong class="important_text">NO</strong>'?></td>
<td><?=isset($Edition['Formats']['V0 (VBR)'])?'<strong class="important_text_alt">YES</strong>':'<strong class="important_text">NO</strong>'?></td>
<td><?=isset($Edition['Formats']['320'])?'<strong class="important_text_alt">YES</strong>':'<strong class="important_text">NO</strong>'?></td>
2011-03-28 14:21:28 +00:00
</tr>
2012-11-06 08:00:20 +00:00
<?
}
}
?>
2011-03-28 14:21:28 +00:00
</table>
</div>
<?
2012-10-11 08:00:15 +00:00
View::show_footer();
2011-03-28 14:21:28 +00:00
?>