mirror of
https://github.com/WhatCD/Gazelle.git
synced 2025-01-07 14:51:38 +00:00
170 lines
5.9 KiB
PHP
170 lines
5.9 KiB
PHP
<?
|
|
define('ARTIST_COLLAGE', 'Artists');
|
|
if (empty($_GET['id']) || !is_number($_GET['id'])) {
|
|
json_die("failure", "bad parameters");
|
|
}
|
|
$CollageID = $_GET['id'];
|
|
|
|
$CacheKey = "collage_$CollageID";
|
|
$CollageData = $Cache->get_value($CacheKey);
|
|
if ($CollageData) {
|
|
list($Name, $Description, $CommentList, $Deleted, $CollageCategoryID, $CreatorID, $Locked, $MaxGroups, $MaxGroupsPerUser, $Updated, $Subscribers) = $CollageData;
|
|
} else {
|
|
$DB->query("
|
|
SELECT
|
|
Name,
|
|
Description,
|
|
UserID,
|
|
Deleted,
|
|
CategoryID,
|
|
Locked,
|
|
MaxGroups,
|
|
MaxGroupsPerUser,
|
|
Updated,
|
|
Subscribers
|
|
FROM collages
|
|
WHERE ID = '$CollageID'");
|
|
if (!$DB->has_results()) {
|
|
json_die("failure");
|
|
}
|
|
list($Name, $Description, $CreatorID, $Deleted, $CollageCategoryID, $Locked, $MaxGroups, $MaxGroupsPerUser, $Updated, $Subscribers) = $DB->next_record(MYSQLI_NUM);
|
|
$CommentList = null;
|
|
$SetCache = true;
|
|
}
|
|
|
|
// TODO: Cache this
|
|
$DB->query("
|
|
SELECT GroupID
|
|
FROM collages_torrents
|
|
WHERE CollageID = $CollageID");
|
|
$TorrentGroups = $DB->collect('GroupID');
|
|
|
|
$JSON = array(
|
|
'id' => (int)$CollageID,
|
|
'name' => $Name,
|
|
'description' => Text::full_format($Description),
|
|
'creatorID' => (int)$CreatorID,
|
|
'deleted' => (bool)$Deleted,
|
|
'collageCategoryID' => (int)$CollageCategoryID,
|
|
'collageCategoryName' => $CollageCats[(int)$CollageCategoryID],
|
|
'locked' => (bool)$Locked,
|
|
'maxGroups' => (int)$MaxGroups,
|
|
'maxGroupsPerUser' => (int)$MaxGroupsPerUser,
|
|
'hasBookmarked' => Bookmarks::has_bookmarked('collage', $CollageID),
|
|
'subscriberCount' => (int)$Subscribers,
|
|
'torrentGroupIDList' => $TorrentGroups
|
|
);
|
|
|
|
if ($CollageCategoryID != array_search(ARTIST_COLLAGE, $CollageCats)) {
|
|
// torrent collage
|
|
$TorrentGroups = array();
|
|
$DB->query("
|
|
SELECT
|
|
ct.GroupID
|
|
FROM collages_torrents AS ct
|
|
JOIN torrents_group AS tg ON tg.ID = ct.GroupID
|
|
WHERE ct.CollageID = '$CollageID'
|
|
ORDER BY ct.Sort");
|
|
$GroupIDs = $DB->collect('GroupID');
|
|
$GroupList = Torrents::get_groups($GroupIDs);
|
|
foreach ($GroupIDs as $GroupID) {
|
|
if (!empty($GroupList[$GroupID])) {
|
|
$GroupDetails = Torrents::array_group($GroupList[$GroupID]);
|
|
if ($GroupDetails['GroupCategoryID'] > 0 && $Categories[$GroupDetails['GroupCategoryID'] - 1] == 'Music') {
|
|
$ArtistForm = $GroupDetails['ExtendedArtists'];
|
|
$JsonMusicInfo = array(
|
|
'composers' => isset($ArtistForm[4]) ? pullmediainfo($ArtistForm[4]) : array(),
|
|
'dj' => isset($ArtistForm[6]) ? pullmediainfo($ArtistForm[6]) : array(),
|
|
'artists' => isset($ArtistForm[1]) ? pullmediainfo($ArtistForm[1]) : array(),
|
|
'with' => isset($ArtistForm[2]) ? pullmediainfo($ArtistForm[2]) : array(),
|
|
'conductor' => isset($ArtistForm[5]) ? pullmediainfo($ArtistForm[5]) : array(),
|
|
'remixedBy' => isset($ArtistForm[3]) ? pullmediainfo($ArtistForm[3]) : array(),
|
|
'producer' => isset($ArtistForm[7]) ? pullmediainfo($ArtistForm[7]) : array()
|
|
);
|
|
} else {
|
|
$JsonMusicInfo = null;
|
|
}
|
|
$TorrentList = array();
|
|
foreach ($GroupDetails['Torrents'] as $Torrent) {
|
|
$TorrentList[] = array(
|
|
'torrentid' => (int)$Torrent['ID'],
|
|
'media' => $Torrent['Media'],
|
|
'format' => $Torrent['Format'],
|
|
'encoding' => $Torrent['Encoding'],
|
|
'remastered' => ($Torrent['Remastered'] == 1),
|
|
'remasterYear' => (int)$Torrent['RemasterYear'],
|
|
'remasterTitle' => $Torrent['RemasterTitle'],
|
|
'remasterRecordLabel' => $Torrent['RemasterRecordLabel'],
|
|
'remasterCatalogueNumber' => $Torrent['RemasterCatalogueNumber'],
|
|
'scene' => ($Torrent['Scene'] == 1),
|
|
'hasLog' => ($Torrent['HasLog'] == 1),
|
|
'hasCue' => ($Torrent['HasCue'] == 1),
|
|
'logScore' => (int)$Torrent['LogScore'],
|
|
'fileCount' => (int)$Torrent['FileCount'],
|
|
'size' => (int)$Torrent['Size'],
|
|
'seeders' => (int)$Torrent['Seeders'],
|
|
'leechers' => (int)$Torrent['Leechers'],
|
|
'snatched' => (int)$Torrent['Snatched'],
|
|
'freeTorrent' => ($Torrent['FreeTorrent'] == 1),
|
|
'reported' => (count(Torrents::get_reports((int)$Torrent['ID'])) > 0),
|
|
'time' => $Torrent['Time']
|
|
);
|
|
}
|
|
$TorrentGroups[] = array(
|
|
'id' => $GroupDetails['GroupID'],
|
|
'name' => $GroupDetails['GroupName'],
|
|
'year' => $GroupDetails['GroupYear'],
|
|
'categoryId' => $GroupDetails['GroupCategoryID'],
|
|
'recordLabel' => $GroupDetails['GroupRecordLabel'],
|
|
'catalogueNumber' => $GroupDetails['GroupCatalogueNumber'],
|
|
'vanityHouse' => $GroupDetails['GroupVanityHouse'],
|
|
'tagList' => $GroupDetails['TagList'],
|
|
'releaseType' => $GroupDetails['ReleaseType'],
|
|
'wikiImage' => $GroupDetails['WikiImage'],
|
|
'musicInfo' => $JsonMusicInfo,
|
|
'torrents' => $TorrentList
|
|
);
|
|
}
|
|
}
|
|
$JSON['torrentgroups'] = $TorrentGroups;
|
|
} else {
|
|
// artist collage
|
|
$DB->query("
|
|
SELECT
|
|
ca.ArtistID,
|
|
ag.Name,
|
|
aw.Image
|
|
FROM collages_artists AS ca
|
|
JOIN artists_group AS ag ON ag.ArtistID=ca.ArtistID
|
|
LEFT JOIN wiki_artists AS aw ON aw.RevisionID = ag.RevisionID
|
|
WHERE ca.CollageID='$CollageID'
|
|
ORDER BY ca.Sort");
|
|
$Artists = array();
|
|
while (list($ArtistID, $ArtistName, $ArtistImage) = $DB->next_record()) {
|
|
$Artists[] = array(
|
|
'id' => (int)$ArtistID,
|
|
'name' => $ArtistName,
|
|
'image' => $ArtistImage
|
|
);
|
|
}
|
|
$JSON['artists'] = $Artists;
|
|
}
|
|
|
|
if (isset($SetCache)) {
|
|
$CollageData = array(
|
|
$Name,
|
|
$Description,
|
|
$CommentList,
|
|
(bool)$Deleted,
|
|
(int)$CollageCategoryID,
|
|
(int)$CreatorID,
|
|
(bool)$Locked,
|
|
(int)$MaxGroups,
|
|
(int)$MaxGroupsPerUser,
|
|
$Updated,
|
|
(int)$Subscribers);
|
|
$Cache->cache_value($CacheKey, $CollageData, 3600);
|
|
}
|
|
|
|
json_print("success", $JSON);
|