query("SELECT Username FROM users_main WHERE ID='$UserID'"); list($Username) = $DB->next_record(); } else { $UserID = $LoggedUser['ID']; } $Sneaky = ($UserID != $LoggedUser['ID']); $Data = $Cache->get_value('bookmarks_torrent_'.$UserID.'_full'); if($Data) { $Data = unserialize($Data); list($K, list($TorrentList, $CollageDataList)) = each($Data); } else { // Build the data for the collage and the torrent list $DB->query("SELECT bt.GroupID, tg.WikiImage, tg.CategoryID, bt.Time FROM bookmarks_torrents AS bt JOIN torrents_group AS tg ON tg.ID=bt.GroupID WHERE bt.UserID='$UserID' ORDER BY bt.Time"); $GroupIDs = $DB->collect('GroupID'); $CollageDataList=$DB->to_array('GroupID', MYSQLI_ASSOC); if(count($GroupIDs)>0) { $TorrentList = get_groups($GroupIDs); $TorrentList = $TorrentList['matches']; } else { $TorrentList = array(); } } $Title = ($Sneaky)?"$Username's bookmarked torrents":'Your bookmarked torrents'; // Loop through the result set, building up $Collage and $TorrentTable // Then we print them. $Collage = array(); $TorrentTable = ''; $NumGroups = 0; $Artists = array(); $Tags = array(); foreach ($TorrentList as $GroupID=>$Group) { list($GroupID, $GroupName, $GroupYear, $GroupRecordLabel, $GroupCatalogueNumber, $TagList, $ReleaseType, $GroupVanityHouse, $Torrents, $GroupArtists) = array_values($Group); list($GroupID2, $Image, $GroupCategoryID, $AddedTime) = array_values($CollageDataList[$GroupID]); // Handle stats and stuff $NumGroups++; if($GroupArtists) { foreach($GroupArtists as $Artist) { if(!isset($Artists[$Artist['id']])) { $Artists[$Artist['id']] = array('name'=>$Artist['name'], 'count'=>1); } else { $Artists[$Artist['id']]['count']++; } } } $TagList = explode(' ',str_replace('_','.',$TagList)); $TorrentTags = array(); foreach($TagList as $Tag) { if(!isset($Tags[$Tag])) { $Tags[$Tag] = array('name'=>$Tag, 'count'=>1); } else { $Tags[$Tag]['count']++; } $TorrentTags[]=''.$Tag.''; } $PrimaryTag = $TagList[0]; $TorrentTags = implode(', ', $TorrentTags); $TorrentTags='
'.$TorrentTags.'
'; $DisplayName = ''; if(count($GroupArtists)>0) { $DisplayName = display_artists(array('1'=>$GroupArtists)); } $DisplayName .= ''.$GroupName.''; if($GroupYear>0) { $DisplayName = $DisplayName. ' ['. $GroupYear .']';} if($GroupVanityHouse) { $DisplayName .= ' [VH]'; } // Start an output buffer, so we can store this output in $TorrentTable ob_start(); if(count($Torrents)>1 || $GroupCategoryID==1) { // Grouped torrents $ShowGroups = !(!empty($LoggedUser['TorrentGrouping']) && $LoggedUser['TorrentGrouping'] == 1); $LastRemasterYear = '-'; $LastRemasterTitle = ''; $LastRemasterRecordLabel = ''; $LastRemasterCatalogueNumber = ''; $LastMedia = ''; $EditionID = 0; unset($FirstUnknown); foreach ($Torrents as $TorrentID => $Torrent) { if ($Torrent['Remastered'] && !$Torrent['RemasterYear']) { $FirstUnknown = !isset($FirstUnknown); } if($Torrent['RemasterTitle'] != $LastRemasterTitle || $Torrent['RemasterYear'] != $LastRemasterYear || $Torrent['RemasterRecordLabel'] != $LastRemasterRecordLabel || $Torrent['RemasterCatalogueNumber'] != $LastRemasterCatalogueNumber || $FirstUnknown || $Torrent['Media'] != $LastMedia) { $EditionID++; if($Torrent['Remastered'] && $Torrent['RemasterYear'] != 0) { $RemasterName = $Torrent['RemasterYear']; $AddExtra = " - "; if($Torrent['RemasterRecordLabel']) { $RemasterName .= $AddExtra.display_str($Torrent['RemasterRecordLabel']); $AddExtra=' / '; } if($Torrent['RemasterCatalogueNumber']) { $RemasterName .= $AddExtra.display_str($Torrent['RemasterCatalogueNumber']); $AddExtra=' / '; } if($Torrent['RemasterTitle']) { $RemasterName .= $AddExtra.display_str($Torrent['RemasterTitle']); $AddExtra=' / '; } $RemasterName .= $AddExtra.display_str($Torrent['Media']); } else { $AddExtra = " / "; if (!$Torrent['Remastered']) { $MasterName = "Original Release"; if($GroupRecordLabel) { $MasterName .= $AddExtra.$GroupRecordLabel; $AddExtra=' / '; } if($GroupCatalogueNumber) { $MasterName .= $AddExtra.$GroupCatalogueNumber; $AddExtra=' / '; } } else { $MasterName = "Unknown Release(s)"; } $MasterName .= $AddExtra.display_str($Torrent['Media']); } } $LastRemasterTitle = $Torrent['RemasterTitle']; $LastRemasterYear = $Torrent['RemasterYear']; $LastRemasterRecordLabel = $Torrent['RemasterRecordLabel']; $LastRemasterCatalogueNumber = $Torrent['RemasterCatalogueNumber']; $LastMedia = $Torrent['Media']; } } else { // Viewing a type that does not require grouping list($TorrentID, $Torrent) = each($Torrents); $DisplayName = ''.$GroupName.''; if(!empty($Torrent['FreeTorrent'])) { $DisplayName .=' Freeleech!'; } } $TorrentTable.=ob_get_clean(); // Album art ob_start(); $DisplayName = ''; if(!empty($GroupArtists)) { $DisplayName.= display_artists(array('1'=>$GroupArtists), false); } $DisplayName .= $GroupName; if($GroupYear>0) { $DisplayName = $DisplayName. ' ['. $GroupYear .']';} $Collage[]=ob_get_clean(); } uasort($Tags, 'compare'); $i = 0; foreach ($Tags as $TagName => $Tag) { $i++; if($i>5) { break; } uasort($Artists, 'compare'); $i = 0; foreach ($Artists as $ID => $Artist) { $i++; if($i>10) { break; } } } $JsonBookmarks = array(); foreach ($TorrentList as $Torrent) { $JsonTorrents = array(); foreach ($Torrent['Torrents'] as $GroupTorrents) { $JsonTorrents[] = array( 'id' => (int) $GroupTorrents['ID'], 'groupId' => (int) $GroupTorrents['GroupID'], 'media' => $GroupTorrents['Media'], 'format' => $GroupTorrents['Format'], 'encoding' => $GroupTorrents['Encoding'], 'remasterYear' => (int) $GroupTorrents['RemasterYear'], 'remastered' => $GroupTorrents['Remastered'] == 1, 'remasterTitle' => $GroupTorrents['RemasterTitle'], 'remasterRecordLabel' => $GroupTorrents['RemasterRecordLabel'], 'remasterCatalogueNumber' => $GroupTorrents['RemasterCatalogueNumber'], 'scene' => $GroupTorrents['Scene'] == 1, 'hasLog' => $GroupTorrents['HasLog'] == 1, 'hasCue' => $GroupTorrents['HasCue'] == 1, 'logScore' => (float) $GroupTorrents['LogScore'], 'fileCount' => (int) $GroupTorrents['FileCount'], 'freeTorrent' => $GroupTorrents['FreeTorrent'] == 1, 'size' => (float) $GroupTorrents['Size'], 'leechers' => (int) $GroupTorrents['Leechers'], 'seeders' => (int) $GroupTorrents['Seeders'], 'snatched' => (int) $GroupTorrents['Snatched'], 'time' => $GroupTorrents['Time'], 'hasFile' => (int) $GroupTorrents['HasFile'] ); } $JsonBookmarks[] = array( 'id' => (int) $Torrent['ID'], 'name' => $Torrent['Name'], 'year' => (int) $Torrent['Year'], 'recordLabel' => $Torrent['RecordLabel'], 'catalogueNumber' => $Torrent['CatalogueNumber'], 'tagList' => $Torrent['TagList'], 'releaseType' => $Torrent['ReleaseType'], 'vanityHouse' => $Torrent['VanityHouse'] == 1, 'image' => $CollageDataList[$Torrent['ID']]['WikiImage'], 'torrents' => $JsonTorrents ); } print json_encode( array( 'status' => 'success', 'response' => array( 'bookmarks' => $JsonBookmarks ) ) ); ?>