mirror of
https://github.com/WhatCD/Gazelle.git
synced 2024-12-14 11:26:26 +00:00
1345 lines
50 KiB
PHP
1345 lines
50 KiB
PHP
<?
|
|
|
|
include(SERVER_ROOT.'/classes/class_text.php'); // Text formatting class
|
|
$Text = new TEXT;
|
|
|
|
include(SERVER_ROOT.'/sections/requests/functions.php');
|
|
include(SERVER_ROOT.'/classes/class_image_tools.php');
|
|
|
|
if (empty($_GET['id']) || !is_numeric($_GET['id']))
|
|
error(404);
|
|
|
|
$UserID = $_GET['id'];
|
|
if($UserID == $LoggedUser['ID']) {
|
|
$OwnProfile = true;
|
|
} else {
|
|
$OwnProfile = false;
|
|
}
|
|
|
|
|
|
|
|
if(check_perms('users_mod')) { // Person viewing is a staff member
|
|
$DB->query("SELECT
|
|
m.Username,
|
|
m.Email,
|
|
m.LastAccess,
|
|
m.IP,
|
|
p.Level AS Class,
|
|
m.Uploaded,
|
|
m.Downloaded,
|
|
m.RequiredRatio,
|
|
m.Title,
|
|
m.torrent_pass,
|
|
m.Enabled,
|
|
m.Paranoia,
|
|
m.Invites,
|
|
m.can_leech,
|
|
m.Visible,
|
|
i.JoinDate,
|
|
i.Info,
|
|
i.Avatar,
|
|
i.Country,
|
|
i.AdminComment,
|
|
i.Donor,
|
|
i.Artist,
|
|
i.Warned,
|
|
i.SupportFor,
|
|
i.RestrictedForums,
|
|
i.PermittedForums,
|
|
i.Inviter,
|
|
inviter.Username,
|
|
COUNT(posts.id) AS ForumPosts,
|
|
i.RatioWatchEnds,
|
|
i.RatioWatchDownload,
|
|
i.DisableAvatar,
|
|
i.DisableInvites,
|
|
i.DisablePosting,
|
|
i.DisableForums,
|
|
i.DisableTagging,
|
|
i.DisableUpload,
|
|
i.DisableWiki,
|
|
i.DisablePM,
|
|
i.DisableIRC,
|
|
i.DisableRequests,
|
|
i.HideCountryChanges,
|
|
m.FLTokens,
|
|
SHA1(i.AdminComment)
|
|
FROM users_main AS m
|
|
JOIN users_info AS i ON i.UserID = m.ID
|
|
LEFT JOIN users_main AS inviter ON i.Inviter = inviter.ID
|
|
LEFT JOIN permissions AS p ON p.ID=m.PermissionID
|
|
LEFT JOIN forums_posts AS posts ON posts.AuthorID = m.ID
|
|
WHERE m.ID = '".$UserID."' GROUP BY AuthorID");
|
|
|
|
if ($DB->record_count() == 0) { // If user doesn't exist
|
|
header("Location: log.php?search=User+".$UserID);
|
|
}
|
|
|
|
list($Username, $Email, $LastAccess, $IP, $Class, $Uploaded, $Downloaded, $RequiredRatio, $CustomTitle, $torrent_pass, $Enabled, $Paranoia, $Invites, $DisableLeech, $Visible, $JoinDate, $Info, $Avatar, $Country, $AdminComment, $Donor, $Artist, $Warned, $SupportFor, $RestrictedForums, $PermittedForums, $InviterID, $InviterName, $ForumPosts, $RatioWatchEnds, $RatioWatchDownload, $DisableAvatar, $DisableInvites, $DisablePosting, $DisableForums, $DisableTagging, $DisableUpload, $DisableWiki, $DisablePM, $DisableIRC, $DisableRequests, $DisableCountry, $FLTokens, $CommentHash) = $DB->next_record(MYSQLI_NUM, array(8,11));
|
|
} else { // Person viewing is a normal user
|
|
$DB->query("SELECT
|
|
m.Username,
|
|
m.Email,
|
|
m.LastAccess,
|
|
m.IP,
|
|
p.Level AS Class,
|
|
m.Uploaded,
|
|
m.Downloaded,
|
|
m.RequiredRatio,
|
|
m.Enabled,
|
|
m.Paranoia,
|
|
m.Invites,
|
|
m.Title,
|
|
m.torrent_pass,
|
|
m.can_leech,
|
|
i.JoinDate,
|
|
i.Info,
|
|
i.Avatar,
|
|
m.FLTokens,
|
|
i.Country,
|
|
i.Donor,
|
|
i.Warned,
|
|
COUNT(posts.id) AS ForumPosts,
|
|
i.Inviter,
|
|
i.DisableInvites,
|
|
inviter.username
|
|
FROM users_main AS m
|
|
JOIN users_info AS i ON i.UserID = m.ID
|
|
LEFT JOIN permissions AS p ON p.ID=m.PermissionID
|
|
LEFT JOIN users_main AS inviter ON i.Inviter = inviter.ID
|
|
LEFT JOIN forums_posts AS posts ON posts.AuthorID = m.ID
|
|
WHERE m.ID = $UserID GROUP BY AuthorID");
|
|
|
|
if ($DB->record_count() == 0) { // If user doesn't exist
|
|
header("Location: log.php?search=User+".$UserID);
|
|
}
|
|
|
|
list($Username, $Email, $LastAccess, $IP, $Class, $Uploaded, $Downloaded, $RequiredRatio, $Enabled, $Paranoia, $Invites, $CustomTitle, $torrent_pass, $DisableLeech, $JoinDate, $Info, $Avatar, $FLTokens, $Country, $Donor, $Warned, $ForumPosts, $InviterID, $DisableInvites, $InviterName, $RatioWatchEnds, $RatioWatchDownload) = $DB->next_record(MYSQLI_NUM, array(9,11));
|
|
}
|
|
|
|
// Image proxy CTs
|
|
$DisplayCustomTitle = $CustomTitle;
|
|
if(check_perms('site_proxy_images') && !empty($CustomTitle)) {
|
|
$DisplayCustomTitle = preg_replace_callback('~src=("?)(http.+?)(["\s>])~', function($Matches) {
|
|
return 'src='.$Matches[1].'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?c=1&i='.urlencode($Matches[2]).$Matches[3];
|
|
}, $CustomTitle);
|
|
}
|
|
|
|
$Paranoia = unserialize($Paranoia);
|
|
if(!is_array($Paranoia)) {
|
|
$Paranoia = array();
|
|
}
|
|
$ParanoiaLevel = 0;
|
|
foreach($Paranoia as $P) {
|
|
$ParanoiaLevel++;
|
|
if(strpos($P, '+')) {
|
|
$ParanoiaLevel++;
|
|
}
|
|
}
|
|
|
|
$JoinedDate = time_diff($JoinDate);
|
|
$LastAccess = time_diff($LastAccess);
|
|
|
|
function check_paranoia_here($Setting) {
|
|
global $Paranoia, $Class, $UserID;
|
|
return check_paranoia($Setting, $Paranoia, $Class, $UserID);
|
|
}
|
|
|
|
$Badges=($Donor) ? '<a href="donate.php"><img src="'.STATIC_SERVER.'common/symbols/donor.png" alt="Donor" /></a>' : '';
|
|
|
|
|
|
$Badges.=($Warned!='0000-00-00 00:00:00') ? '<img src="'.STATIC_SERVER.'common/symbols/warned.png" alt="Warned" />' : '';
|
|
$Badges.=($Enabled == '1' || $Enabled == '0' || !$Enabled) ? '': '<img src="'.STATIC_SERVER.'common/symbols/disabled.png" alt="Banned" />';
|
|
|
|
|
|
show_header($Username,'user,bbcode,requests');
|
|
?>
|
|
<div class="thin">
|
|
<h2><?=$Username?></h2>
|
|
<div class="linkbox">
|
|
<? if (!$OwnProfile) { ?>
|
|
[<a href="inbox.php?action=compose&to=<?=$UserID?>">Send Message</a>]
|
|
<? $DB->query("SELECT FriendID FROM friends WHERE UserID='$LoggedUser[ID]' AND FriendID='$UserID'");
|
|
if($DB->record_count() == 0) { ?>
|
|
[<a href="friends.php?action=add&friendid=<?=$UserID?>&auth=<?=$LoggedUser['AuthKey']?>">Add to friends</a>]
|
|
<? }?>
|
|
[<a href="reports.php?action=report&type=user&id=<?=$UserID?>">Report User</a>]
|
|
<?
|
|
|
|
}
|
|
|
|
if (check_perms('users_edit_profiles', $Class)) {
|
|
?>
|
|
[<a href="user.php?action=edit&userid=<?=$UserID?>">Settings</a>]
|
|
<? }
|
|
if (check_perms('users_view_invites', $Class)) {
|
|
?>
|
|
[<a href="user.php?action=invite&userid=<?=$UserID?>">Invites</a>]
|
|
<? }
|
|
if (check_perms('admin_manage_permissions', $Class)) {
|
|
?>
|
|
[<a href="user.php?action=permissions&userid=<?=$UserID?>">Permissions</a>]
|
|
<? }
|
|
if (check_perms('users_logout', $Class) && check_perms('users_view_ips', $Class)) {
|
|
?>
|
|
[<a href="user.php?action=sessions&userid=<?=$UserID?>">Sessions</a>]
|
|
<? }
|
|
if (check_perms('admin_reports')) {
|
|
?>
|
|
[<a href="reportsv2.php?view=reporter&id=<?=$UserID?>">Reports</a>]
|
|
<? }
|
|
if (check_perms('users_mod')) {
|
|
?>
|
|
[<a href="userhistory.php?action=token_history&userid=<?=$UserID?>">FL Tokens</a>]
|
|
<? }
|
|
if (check_perms('admin_clear_cache') && check_perms('users_override_paranoia')) {
|
|
?>
|
|
[<a href="user.php?action=clearcache&id=<?=$UserID?>">Clear Cache</a>]
|
|
<? } ?>
|
|
</div>
|
|
|
|
<div class="sidebar">
|
|
<? if ($Avatar && empty($HeavyInfo['DisableAvatars'])) {
|
|
if(check_perms('site_proxy_images') && !empty($Avatar)) {
|
|
$Avatar = 'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?c=1&avatar='.$UserID.'&i='.urlencode($Avatar);
|
|
}
|
|
?>
|
|
<div class="box box_image box_image_avatar">
|
|
<div class="head colhead_dark">Avatar</div>
|
|
<div align="center"><img src="<?=display_str($Avatar)?>" width="150" style="max-height:400px;" alt="<?=$Username?>'s avatar" /></div>
|
|
</div>
|
|
<? } ?>
|
|
<div class="box box_info box_userinfo_stats">
|
|
<div class="head colhead_dark">Stats</div>
|
|
<ul class="stats nobullet">
|
|
<li>Joined: <?=$JoinedDate?></li>
|
|
<? if (($Override = check_paranoia_here('lastseen'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Last Seen: <?=$LastAccess?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('uploaded'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Uploaded: <?=get_size($Uploaded)?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('downloaded'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Downloaded: <?=get_size($Downloaded)?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('ratio'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Ratio: <?=ratio($Uploaded, $Downloaded)?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('requiredratio')) && isset($RequiredRatio)) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Required ratio: <?=number_format((double)$RequiredRatio, 2)?></li>
|
|
<? } ?>
|
|
<? if ($OwnProfile || ($Override=check_paranoia_here(false)) || check_perms('users_mod')) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> ><a href="userhistory.php?action=token_history&userid=<?=$UserID?>">Tokens</a>: <?=number_format($FLTokens)?></li>
|
|
<? } ?>
|
|
</ul>
|
|
</div>
|
|
<?
|
|
|
|
if (check_paranoia_here('requestsfilled_count') || check_paranoia_here('requestsfilled_bounty')) {
|
|
$DB->query("SELECT COUNT(DISTINCT r.ID), SUM(rv.Bounty) FROM requests AS r LEFT JOIN requests_votes AS rv ON r.ID=rv.RequestID WHERE r.FillerID = ".$UserID);
|
|
list($RequestsFilled, $TotalBounty) = $DB->next_record();
|
|
} else {
|
|
$RequestsFilled = $TotalBounty = 0;
|
|
}
|
|
|
|
if (check_paranoia_here('requestsvoted_count') || check_paranoia_here('requestsvoted_bounty')) {
|
|
$DB->query("SELECT COUNT(rv.RequestID), SUM(rv.Bounty) FROM requests_votes AS rv WHERE rv.UserID = ".$UserID);
|
|
list($RequestsVoted, $TotalSpent) = $DB->next_record();
|
|
} else {
|
|
$RequestsVoted = $TotalSpent = 0;
|
|
}
|
|
|
|
if(check_paranoia_here('uploads+')) {
|
|
$DB->query("SELECT COUNT(ID) FROM torrents WHERE UserID='$UserID'");
|
|
list($Uploads) = $DB->next_record();
|
|
} else {
|
|
$Uploads = 0;
|
|
}
|
|
|
|
if (check_paranoia_here('artistsadded')) {
|
|
$DB->query("SELECT COUNT(ta.ArtistID) FROM torrents_artists AS ta WHERE ta.UserID = ".$UserID);
|
|
list($ArtistsAdded) = $DB->next_record();
|
|
} else {
|
|
$ArtistsAdded = 0;
|
|
}
|
|
|
|
include(SERVER_ROOT.'/classes/class_user_rank.php');
|
|
$Rank = new USER_RANK;
|
|
|
|
$UploadedRank = $Rank->get_rank('uploaded', $Uploaded);
|
|
$DownloadedRank = $Rank->get_rank('downloaded', $Downloaded);
|
|
$UploadsRank = $Rank->get_rank('uploads', $Uploads);
|
|
$RequestRank = $Rank->get_rank('requests', $RequestsFilled);
|
|
$PostRank = $Rank->get_rank('posts', $ForumPosts);
|
|
$BountyRank = $Rank->get_rank('bounty', $TotalSpent);
|
|
$ArtistsRank = $Rank->get_rank('artists', $ArtistsAdded);
|
|
|
|
if($Downloaded == 0) {
|
|
$Ratio = 1;
|
|
} elseif($Uploaded == 0) {
|
|
$Ratio = 0.5;
|
|
} else {
|
|
$Ratio = round($Uploaded/$Downloaded, 2);
|
|
}
|
|
$OverallRank = $Rank->overall_score($UploadedRank, $DownloadedRank, $UploadsRank, $RequestRank, $PostRank, $BountyRank, $ArtistsRank, $Ratio);
|
|
|
|
?>
|
|
<div class="box box_info box_userinfo_percentile">
|
|
<div class="head colhead_dark">Percentile Rankings (Hover for values)</div>
|
|
<ul class="stats nobullet">
|
|
<? if (($Override=check_paranoia_here('uploaded'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> title="<?=get_size($Uploaded)?>">Data uploaded: <?=$UploadedRank === false ? 'Server busy' : number_format($UploadedRank)?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('downloaded'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> title="<?=get_size($Downloaded)?>">Data downloaded: <?=$DownloadedRank === false ? 'Server busy' : number_format($DownloadedRank)?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('uploads+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> title="<?=$Uploads?>">Torrents uploaded: <?=$UploadsRank === false ? 'Server busy' : number_format($UploadsRank)?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('requestsfilled_count'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> title="<?=$RequestsFilled?>">Requests filled: <?=$RequestRank === false ? 'Server busy' : number_format($RequestRank)?></li>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('requestsvoted_bounty'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> title="<?=get_size($TotalSpent)?>">Bounty spent: <?=$BountyRank === false ? 'Server busy' : number_format($BountyRank)?></li>
|
|
<? } ?>
|
|
<li title="<?=$ForumPosts?>">Posts made: <?=$PostRank === false ? 'Server busy' : number_format($PostRank)?></li>
|
|
<? if (($Override=check_paranoia_here('artistsadded'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> title="<?=$ArtistsAdded?>">Artists added: <?=$ArtistsRank === false ? 'Server busy' : number_format($ArtistsRank)?></li>
|
|
<? } ?>
|
|
<? if (check_paranoia_here(array('uploaded', 'downloaded', 'uploads+', 'requestsfilled_count', 'requestsvoted_bounty', 'artistsadded'))) { ?>
|
|
<li><strong>Overall rank: <?=$OverallRank === false ? 'Server busy' : number_format($OverallRank)?></strong></li>
|
|
<? } ?>
|
|
</ul>
|
|
</div>
|
|
<?
|
|
if (check_perms('users_mod', $Class) || check_perms('users_view_ips',$Class) || check_perms('users_view_keys',$Class)) {
|
|
$DB->query("SELECT COUNT(*) FROM users_history_passwords WHERE UserID='$UserID'");
|
|
list($PasswordChanges) = $DB->next_record();
|
|
if (check_perms('users_view_keys',$Class)) {
|
|
$DB->query("SELECT COUNT(*) FROM users_history_passkeys WHERE UserID='$UserID'");
|
|
list($PasskeyChanges) = $DB->next_record();
|
|
}
|
|
if (check_perms('users_view_ips',$Class)) {
|
|
$DB->query("SELECT COUNT(DISTINCT IP) FROM users_history_ips WHERE UserID='$UserID'");
|
|
list($IPChanges) = $DB->next_record();
|
|
$DB->query("SELECT COUNT(DISTINCT IP) FROM xbt_snatched WHERE uid='$UserID' AND IP != ''");
|
|
list($TrackerIPs) = $DB->next_record();
|
|
}
|
|
if (check_perms('users_view_email',$Class)) {
|
|
$DB->query("SELECT COUNT(*) FROM users_history_emails WHERE UserID='$UserID'");
|
|
list($EmailChanges) = $DB->next_record();
|
|
}
|
|
?>
|
|
<div class="box box_info box_userinfo_history">
|
|
<div class="head colhead_dark">History</div>
|
|
<ul class="stats nobullet">
|
|
<? if (check_perms('users_view_email',$Class)) { ?>
|
|
<li>Emails: <?=number_format($EmailChanges)?> [<a href="userhistory.php?action=email2&userid=<?=$UserID?>">View</a>] [<a href="userhistory.php?action=email&userid=<?=$UserID?>">Legacy view</a>]</li>
|
|
<?
|
|
}
|
|
if (check_perms('users_view_ips',$Class)) {
|
|
?>
|
|
<li>IPs: <?=number_format($IPChanges)?> [<a href="userhistory.php?action=ips&userid=<?=$UserID?>">View</a>] [<a href="userhistory.php?action=ips&userid=<?=$UserID?>&usersonly=1">View Users</a>]</li>
|
|
<? if (check_perms('users_view_ips',$Class) && check_perms('users_mod',$Class)) { ?>
|
|
<li>Tracker IPs: <?=number_format($TrackerIPs)?> [<a href="userhistory.php?action=tracker_ips&userid=<?=$UserID?>">View</a>]</li>
|
|
<? } ?>
|
|
<?
|
|
}
|
|
if (check_perms('users_view_keys',$Class)) {
|
|
?>
|
|
<li>Passkeys: <?=number_format($PasskeyChanges)?> [<a href="userhistory.php?action=passkeys&userid=<?=$UserID?>">View</a>]</li>
|
|
<?
|
|
}
|
|
if (check_perms('users_mod', $Class)) {
|
|
?>
|
|
<li>Passwords: <?=number_format($PasswordChanges)?> [<a href="userhistory.php?action=passwords&userid=<?=$UserID?>">View</a>]</li>
|
|
<li>Stats: N/A [<a href="userhistory.php?action=stats&userid=<?=$UserID?>">View</a>]</li>
|
|
<?
|
|
|
|
}
|
|
?>
|
|
</ul>
|
|
</div>
|
|
<? } ?>
|
|
<div class="box box_info box_userinfo_personal">
|
|
<div class="head colhead_dark">Personal</div>
|
|
<ul class="stats nobullet">
|
|
<li>Class: <?=$ClassLevels[$Class]['Name']?></li>
|
|
<?
|
|
$UserInfo = user_info($UserID);
|
|
if (!empty($UserInfo['ExtraClasses'])) {
|
|
?>
|
|
<li>
|
|
<ul class="stats">
|
|
<?
|
|
foreach($UserInfo['ExtraClasses'] as $PermID => $Val) { ?>
|
|
<li><?=$Classes[$PermID]['Name']?></li>
|
|
<? }
|
|
?>
|
|
</ul>
|
|
</li>
|
|
<?
|
|
}
|
|
// An easy way for people to measure the paranoia of a user, for e.g. contest eligibility
|
|
if($ParanoiaLevel == 0) {
|
|
$ParanoiaLevelText = 'Off';
|
|
} elseif($ParanoiaLevel == 1) {
|
|
$ParanoiaLevelText = 'Very Low';
|
|
} elseif($ParanoiaLevel <= 5) {
|
|
$ParanoiaLevelText = 'Low';
|
|
} elseif($ParanoiaLevel <= 20) {
|
|
$ParanoiaLevelText = 'High';
|
|
} else {
|
|
$ParanoiaLevelText = 'Very high';
|
|
}
|
|
?>
|
|
<li>Paranoia level: <span title="<?=$ParanoiaLevel?>"><?=$ParanoiaLevelText?></span></li>
|
|
<? if (check_perms('users_view_email',$Class) || $OwnProfile) { ?>
|
|
<li>Email: <a href="mailto:<?=display_str($Email)?>"><?=display_str($Email)?></a>
|
|
<? if (check_perms('users_view_email',$Class)) { ?>
|
|
[<a href="user.php?action=search&email_history=on&email=<?=display_str($Email)?>" title="Search">S</a>]
|
|
<? } ?>
|
|
</li>
|
|
<? }
|
|
|
|
if (check_perms('users_view_ips',$Class)) {
|
|
?>
|
|
<li>IP: <?=display_ip($IP)?></li>
|
|
<li>Host: <?=get_host($IP)?></li>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_view_keys',$Class) || $OwnProfile) {
|
|
?>
|
|
<li>Passkey: <a href="#" onclick="this.innerHTML='<?=display_str($torrent_pass)?>'; return false;">[View]</a></li>
|
|
<? }
|
|
if (check_perms('users_view_invites')) {
|
|
if (!$InviterID) {
|
|
$Invited='<span style="font-style: italic;">Nobody</span>';
|
|
} else {
|
|
$Invited='<a href="user.php?id='.$InviterID.'">'.$InviterName.'</a>';
|
|
}
|
|
|
|
?>
|
|
<li>Invited By: <?=$Invited?></li>
|
|
<li>Invites: <?
|
|
$DB->query("SELECT count(InviterID) FROM invites WHERE InviterID = '$UserID'");
|
|
list($Pending) = $DB->next_record();
|
|
if($DisableInvites) {
|
|
echo 'X';
|
|
} else {
|
|
echo number_format($Invites);
|
|
}
|
|
echo " (".$Pending.")"
|
|
?></li>
|
|
<?
|
|
}
|
|
|
|
if (!isset($SupportFor)) {
|
|
$DB->query("SELECT SupportFor FROM users_info WHERE UserID = ".$LoggedUser['ID']);
|
|
list($SupportFor) = $DB->next_record();
|
|
}
|
|
if ($Override=check_perms('users_mod') || $OwnProfile || !empty($SupportFor)) {
|
|
?>
|
|
<li <?= $Override===2 || $SupportFor ? 'class="paranoia_override"' : ''?>>Clients: <?
|
|
$DB->query("SELECT DISTINCT useragent FROM xbt_files_users WHERE uid = ".$UserID);
|
|
while(list($Client) = $DB->next_record()) {
|
|
if (strlen($Clients) > 0) {
|
|
$Clients .= "; ".$Client;
|
|
} else {
|
|
$Clients = $Client;
|
|
}
|
|
}
|
|
echo $Clients;
|
|
?></li>
|
|
<?
|
|
}
|
|
?>
|
|
</ul>
|
|
</div>
|
|
<?
|
|
// These stats used to be all together in one UNION'd query
|
|
// But we broke them up because they had a habit of locking each other to death.
|
|
// They all run really quickly anyways.
|
|
$DB->query("SELECT COUNT(x.uid), COUNT(DISTINCT x.fid) FROM xbt_snatched AS x INNER JOIN torrents AS t ON t.ID=x.fid WHERE x.uid='$UserID'");
|
|
list($Snatched, $UniqueSnatched) = $DB->next_record();
|
|
|
|
$DB->query("SELECT COUNT(ID) FROM torrents_comments WHERE AuthorID='$UserID'");
|
|
list($NumComments) = $DB->next_record();
|
|
|
|
$DB->query("SELECT COUNT(ID) FROM collages WHERE Deleted='0' AND UserID='$UserID'");
|
|
list($NumCollages) = $DB->next_record();
|
|
|
|
$DB->query("SELECT COUNT(DISTINCT CollageID) FROM collages_torrents AS ct JOIN collages ON CollageID = ID WHERE Deleted='0' AND ct.UserID='$UserID'");
|
|
list($NumCollageContribs) = $DB->next_record();
|
|
|
|
$DB->query("SELECT COUNT(DISTINCT GroupID) FROM torrents WHERE UserID = '$UserID'");
|
|
list($UniqueGroups) = $DB->next_record();
|
|
|
|
$DB->query("SELECT COUNT(ID) FROM torrents WHERE ((LogScore = 100 AND Format = 'FLAC') OR (Media = 'Vinyl' AND Format = 'FLAC') OR (Media = 'WEB' AND Format = 'FLAC') OR (Media = 'DVD' AND Format = 'FLAC') OR (Media = 'Soundboard' AND Format = 'FLAC') OR (Media = 'Cassette' AND Format = 'FLAC') OR (Media = 'SACD' AND Format = 'FLAC') OR (Media = 'Blu-ray' AND Format = 'FLAC') OR (Media = 'DAT' AND Format = 'FLAC')) AND UserID = '$UserID'");
|
|
list($PerfectFLACs) = $DB->next_record();
|
|
?>
|
|
<div class="box box_info box_userinfo_community">
|
|
<div class="head colhead_dark">Community</div>
|
|
<ul class="stats nobullet">
|
|
<li>Forum Posts: <?=number_format($ForumPosts)?> [<a href="userhistory.php?action=posts&userid=<?=$UserID?>" title="View">View</a>]</li>
|
|
<? if (($Override=check_paranoia_here('torrentcomments+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Torrent Comments: <?=number_format($NumComments)?>
|
|
<? if($Override=check_paranoia_here('torrentcomments')) { ?>[<a href="comments.php?id=<?=$UserID?>" <?= $Override===2 ? 'class="paranoia_override"'
|
|
: ''
|
|
?> title="View">View</a>]
|
|
<? } ?>
|
|
</li>
|
|
<? }
|
|
if (($Override=check_paranoia_here('collages+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Collages started: <?=number_format($NumCollages)?>
|
|
<? if(($Override=check_paranoia_here('collages'))) { ?>[<a <?= ($Override===2) ? 'class="paranoia_override"'
|
|
:'' ?>
|
|
href="collages.php?userid=<?=$UserID?>" title="View">View</a>]
|
|
<? } ?>
|
|
</li>
|
|
<? }
|
|
if (($Override=check_paranoia_here('collagecontribs+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Collages contributed to: <? echo number_format($NumCollageContribs);
|
|
if (($Override=check_paranoia_here('collagecontribs'))) {
|
|
?> [<a <?= ($Override===2) ?
|
|
'class="paranoia_override"' : ''?> href="collages.php?userid=<?=$UserID?>&contrib=1" title="View">View</a>]
|
|
<? } ?>
|
|
</li>
|
|
<? }
|
|
|
|
//Let's see if we can view requests because of reasons
|
|
$ViewAll = check_paranoia_here('requestsfilled_list');
|
|
$ViewCount = check_paranoia_here('requestsfilled_count');
|
|
$ViewBounty = check_paranoia_here('requestsfilled_bounty');
|
|
|
|
if ($ViewCount && !$ViewBounty && !$ViewAll) { ?>
|
|
<li>Requests filled: <?=number_format($RequestsFilled)?></li>
|
|
<? } elseif(!$ViewCount && $ViewBounty && !$ViewAll) { ?>
|
|
<li>Requests voted: <?=get_size($TotalSpent)?> collected</li>
|
|
<? } elseif($ViewCount && $ViewBounty && !$ViewAll) { ?>
|
|
<li>Requests filled: <?=number_format($RequestsFilled)?> for <?=get_size($TotalBounty)?></li>
|
|
<? } elseif($ViewAll) { ?>
|
|
<li>
|
|
<span <?= ($ViewCount===2) ? 'class="paranoia_override"' : ''?> >Requests filled: <?=number_format($RequestsFilled)?> </span>
|
|
<span <?= ($ViewBounty===2) ? 'class="paranoia_override"' : ''?>> for <?=get_size($TotalBounty) ?> </span>
|
|
[<a href="requests.php?type=filled&userid=<?=$UserID?>" <?= ($ViewAll===2) ? 'class="paranoia_override"' : ''?> title="View">View</a>]
|
|
</li>
|
|
<? }
|
|
|
|
//Let's see if we can view requests because of reasons
|
|
$ViewAll = check_paranoia_here('requestsvoted_list');
|
|
$ViewCount = check_paranoia_here('requestsvoted_count');
|
|
$ViewBounty = check_paranoia_here('requestsvoted_bounty');
|
|
|
|
if ($ViewCount && !$ViewBounty && !$ViewAll) { ?>
|
|
<li>Requests voted: <?=number_format($RequestsVoted)?></li>
|
|
<? } elseif(!$ViewCount && $ViewBounty && !$ViewAll) { ?>
|
|
<li>Requests voted: <?=get_size($TotalSpent)?> spent</li>
|
|
<? } elseif($ViewCount && $ViewBounty && !$ViewAll) { ?>
|
|
<li>Requests voted: <?=number_format($RequestsVoted)?> for <?=get_size($TotalSpent)?></li>
|
|
<? } elseif($ViewAll) { ?>
|
|
<li>
|
|
<span <?= ($ViewCount===2) ? 'class="paranoia_override"' : ''?> >Requests voted: <?=number_format($RequestsVoted)?> </span>
|
|
<span <?= ($ViewBounty===2) ? 'class="paranoia_override"' : ''?>> for <?=get_size($TotalSpent)?> </span>
|
|
[<a href="requests.php?type=voted&userid=<?=$UserID?>" <?= ($ViewAll===2) ? 'class="paranoia_override"' : ''?> title="View">View</a>]
|
|
</li>
|
|
<? }
|
|
if (($Override=check_paranoia_here('uploads+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Uploaded: <?=number_format($Uploads)?>
|
|
<? if(($Override=check_paranoia_here('uploads'))) { ?>[<a <?= $Override===2 ? 'class="paranoia_override"' :'' ?> href="torrents.php?type=uploaded&userid=<?=$UserID?>" title="View">View</a>]<? if(check_perms('zip_downloader')) { ?> [<a href="torrents.php?action=redownload&type=uploads&userid=<?=$UserID?>"
|
|
onclick="return confirm('If you no longer have the content, your ratio WILL be affected; be sure to check the size of all albums before redownloading.');">Download</a>]<? } } ?>
|
|
</li>
|
|
<? }
|
|
if (($Override=check_paranoia_here('uniquegroups+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >
|
|
Unique Groups: <?echo number_format($UniqueGroups);
|
|
if(($Override=check_paranoia_here('uniquegroups'))) {?>
|
|
[<a <?= $Override===2 ? 'class="paranoia_override"' :'' ?> href="torrents.php?type=uploaded&userid=<?=$UserID?>&filter=uniquegroup">View</a>]
|
|
<?}?>
|
|
</li>
|
|
<? }
|
|
if (($Override=check_paranoia_here('perfectflacs+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >"Perfect" FLACs: <?echo number_format($PerfectFLACs);
|
|
if (($Override=check_paranoia_here('perfectflacs'))) { ?>
|
|
[<a <?= $Override===2 ? 'class="paranoia_override"' :'' ?> href="torrents.php?type=uploaded&userid=<?=$UserID?>&filter=perfectflac">View</a>]</li>
|
|
<? }
|
|
}
|
|
|
|
if (check_paranoia_here('seeding+') || check_paranoia_here('leeching+')) {
|
|
$DB->query("SELECT IF(remaining=0,'Seeding','Leeching') AS Type, COUNT(x.uid) FROM xbt_files_users AS x INNER JOIN torrents AS t ON t.ID=x.fid WHERE x.uid='$UserID' AND x.active=1 GROUP BY Type");
|
|
$PeerCount = $DB->to_array(0, MYSQLI_NUM, false);
|
|
$Seeding = isset($PeerCount['Seeding'][1]) ? $PeerCount['Seeding'][1] : 0;
|
|
$Leeching = isset($PeerCount['Leeching'][1]) ? $PeerCount['Leeching'][1] : 0;
|
|
}
|
|
?>
|
|
<? if (($Override=check_paranoia_here('seeding+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Seeding: <?=number_format($Seeding)?> <?
|
|
if(($AOverride=check_paranoia_here('seeding'))) {
|
|
echo ((($Override=check_paranoia_here('snatched')) && $UniqueSnatched > 0 )
|
|
? '<span ' .($Override===2 ? 'class="paranoia_override" ' : '').' >(' . 100*min(1,round($Seeding/$UniqueSnatched,2)).'%)</span> '
|
|
: ''); ?>
|
|
[<a href="torrents.php?type=seeding&userid=<?=$UserID?>" <?= $AOverride===2 ? 'class="paranoia_override"' :'' ?> title="View">View</a>]
|
|
<? if (check_perms('zip_downloader')) { ?>
|
|
[<a href="torrents.php?action=redownload&type=seeding&userid=<?=$UserID?>" onclick="return confirm('If you no longer have the content, your ratio WILL be affected; be sure to check the size of all albums before redownloading.');">Download</a>]
|
|
<? } ?>
|
|
<?} ?>
|
|
</li>
|
|
<? }
|
|
if (($Override=check_paranoia_here('leeching+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Leeching: <? echo number_format($Leeching);
|
|
if(($Override=check_paranoia_here('leeching'))) { ?>
|
|
[<a <?= $Override===2 ? 'class="paranoia_override"' : ''?> href="torrents.php?type=leeching&userid=<?=$UserID?>" title="View">View</a>]
|
|
<? }
|
|
echo ($DisableLeech == 0 && check_perms('users_view_ips')) ? "<strong> (Disabled)</strong>" : ""?>
|
|
</li>
|
|
<? }
|
|
?>
|
|
<? if (($Override=check_paranoia_here('snatched+'))) { ?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Snatched: <?=number_format($Snatched)?>
|
|
<? if(($Override=check_perms('site_view_torrent_snatchlist', $Class))) { ?>
|
|
(<?= $Override === 2 ? '<span class="paranoia_override">'.number_format($UniqueSnatched).'</span>' : number_format($UniqueSnatched) ?>)
|
|
<? } ?>
|
|
<? } ?>
|
|
<? if (($Override=check_paranoia_here('snatched'))) { ?>
|
|
[<a href="torrents.php?type=snatched&userid=<?=$UserID?>" <?= $Override===2 ? 'class="paranoia_override"' : ''?> title="View">View</a>]<? if(check_perms('zip_downloader')) { ?> [<a href="torrents.php?action=redownload&type=snatches&userid=<?=$UserID?>" onclick="return confirm('If you no longer have the content, your ratio WILL be affected, be sure to check the size of all albums before redownloading.');">Download</a>]<? } ?>
|
|
</li>
|
|
<? }
|
|
|
|
if(($Override=check_perms('site_view_torrent_snatchlist', $Class))) {
|
|
$DB->query("SELECT COUNT(ud.UserID), COUNT(DISTINCT ud.TorrentID) FROM users_downloads AS ud INNER JOIN torrents AS t ON t.ID=ud.TorrentID WHERE ud.UserID='$UserID'");
|
|
list($NumDownloads, $UniqueDownloads) = $DB->next_record();
|
|
?>
|
|
<li <?= $Override===2 ? 'class="paranoia_override"' : ''?> >Downloaded: <?=number_format($NumDownloads)?> (<?=number_format($UniqueDownloads)?>) [<a href="torrents.php?type=downloaded&userid=<?=$UserID?>" title="View">View</a>]</li>
|
|
<?
|
|
}
|
|
|
|
if(($Override=check_paranoia_here('invitedcount'))) {
|
|
$DB->query("SELECT COUNT(UserID) FROM users_info WHERE Inviter='$UserID'");
|
|
list($Invited) = $DB->next_record();
|
|
?>
|
|
<li>Invited: <?=number_format($Invited)?></li>
|
|
<?
|
|
} ?>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
<div class="main_column">
|
|
<?
|
|
if ($RatioWatchEnds!='0000-00-00 00:00:00'
|
|
&& (time() < strtotime($RatioWatchEnds))
|
|
&& ($Downloaded*$RequiredRatio)>$Uploaded
|
|
) {
|
|
?>
|
|
<div class="box">
|
|
<div class="head">Ratio watch</div>
|
|
<div class="pad">This user is currently on ratio watch and must upload <?=get_size(($Downloaded*$RequiredRatio)-$Uploaded)?> in the next <?=time_diff($RatioWatchEnds)?>, or their leeching privileges will be revoked. Amount downloaded while on ratio watch: <?=get_size($Downloaded-$RatioWatchDownload)?></div>
|
|
</div>
|
|
<? } ?>
|
|
<div class="box">
|
|
<div class="head">
|
|
<span style="float:left;">Profile<? if ($CustomTitle) { echo " - ".html_entity_decode($DisplayCustomTitle); } ?></span>
|
|
<span style="float:right;"><?=!empty($Badges)?"$Badges ":''?><a href="#" onclick="$('#profilediv').toggle(); this.innerHTML=(this.innerHTML=='(Hide)'?'(Show)':'(Hide)'); return false;">(Hide)</a></span>
|
|
</div>
|
|
<div class="pad" id="profilediv">
|
|
<? if (!$Info) { ?>
|
|
This profile is currently empty.
|
|
<?
|
|
} else {
|
|
echo $Text->full_format($Info);
|
|
}
|
|
|
|
?>
|
|
</div>
|
|
</div>
|
|
<?
|
|
if ($Snatched > 4 && check_paranoia_here('snatched')) {
|
|
$RecentSnatches = $Cache->get_value('recent_snatches_'.$UserID);
|
|
if(!is_array($RecentSnatches)){
|
|
$DB->query("SELECT
|
|
g.ID,
|
|
g.Name,
|
|
g.WikiImage
|
|
FROM xbt_snatched AS s
|
|
INNER JOIN torrents AS t ON t.ID=s.fid
|
|
INNER JOIN torrents_group AS g ON t.GroupID=g.ID
|
|
WHERE s.uid='$UserID'
|
|
AND g.CategoryID='1'
|
|
AND g.WikiImage <> ''
|
|
GROUP BY g.ID
|
|
ORDER BY s.tstamp DESC
|
|
LIMIT 5");
|
|
$RecentSnatches = $DB->to_array();
|
|
|
|
$Artists = get_artists($DB->collect('ID'));
|
|
foreach($RecentSnatches as $Key => $SnatchInfo) {
|
|
$RecentSnatches[$Key]['Artist'] = display_artists($Artists[$SnatchInfo['ID']], false, true);
|
|
}
|
|
$Cache->cache_value('recent_snatches_'.$UserID, $RecentSnatches, 0); //inf cache
|
|
}
|
|
?>
|
|
<table class="layout recent" id="recent_snatches" cellpadding="0" cellspacing="0" border="0">
|
|
<tr class="colhead">
|
|
<td colspan="5">Recent Snatches</td>
|
|
</tr>
|
|
<tr>
|
|
<?
|
|
foreach($RecentSnatches as $RS) { ?>
|
|
<td>
|
|
<a href="torrents.php?id=<?=$RS['ID']?>" title="<?=display_str($RS['Artist'])?><?=display_str($RS['Name'])?>"><img src="<?=to_thumbnail($RS['WikiImage'])?>" alt="<?=display_str($RS['Artist'])?><?=display_str($RS['Name'])?>" width="107" /></a>
|
|
</td>
|
|
<? } ?>
|
|
</tr>
|
|
</table>
|
|
<?
|
|
}
|
|
|
|
if(!isset($Uploads)) { $Uploads = 0; }
|
|
if ($Uploads > 4 && check_paranoia_here('uploads')) {
|
|
$RecentUploads = $Cache->get_value('recent_uploads_'.$UserID);
|
|
if(!is_array($RecentUploads)){
|
|
$DB->query("SELECT
|
|
g.ID,
|
|
g.Name,
|
|
g.WikiImage
|
|
FROM torrents_group AS g
|
|
INNER JOIN torrents AS t ON t.GroupID=g.ID
|
|
WHERE t.UserID='$UserID'
|
|
AND g.CategoryID='1'
|
|
AND g.WikiImage <> ''
|
|
GROUP BY g.ID
|
|
ORDER BY t.Time DESC
|
|
LIMIT 5");
|
|
$RecentUploads = $DB->to_array();
|
|
$Artists = get_artists($DB->collect('ID'));
|
|
foreach($RecentUploads as $Key => $UploadInfo) {
|
|
$RecentUploads[$Key]['Artist'] = display_artists($Artists[$UploadInfo['ID']], false, true);
|
|
}
|
|
$Cache->cache_value('recent_uploads_'.$UserID, $RecentUploads, 0); //inf cache
|
|
}
|
|
?>
|
|
<table class="layout recent" id="recent_uploads" cellpadding="0" cellspacing="0" border="0">
|
|
<tr class="colhead">
|
|
<td colspan="5">Recent Uploads</td>
|
|
</tr>
|
|
<tr>
|
|
<? foreach($RecentUploads as $RU) { ?>
|
|
<td>
|
|
<a href="torrents.php?id=<?=$RU['ID']?>" title="<?=$RU['Artist']?><?=$RU['Name']?>"><img src="<?=to_thumbnail($RU['WikiImage'])?>" alt="<?=$RU['Artist']?><?=$RU['Name']?>" width="107" /></a>
|
|
</td>
|
|
<? } ?>
|
|
</tr>
|
|
</table>
|
|
<?
|
|
}
|
|
|
|
$DB->query("SELECT ID, Name FROM collages WHERE UserID='$UserID' AND CategoryID='0' AND Deleted='0' ORDER BY Featured DESC, Name ASC");
|
|
$Collages = $DB->to_array();
|
|
$FirstCol = true;
|
|
foreach ($Collages as $CollageInfo) {
|
|
list($CollageID, $CName) = $CollageInfo;
|
|
$DB->query("SELECT ct.GroupID,
|
|
tg.WikiImage,
|
|
tg.CategoryID
|
|
FROM collages_torrents AS ct
|
|
JOIN torrents_group AS tg ON tg.ID=ct.GroupID
|
|
WHERE ct.CollageID='$CollageID'
|
|
ORDER BY ct.Sort LIMIT 5");
|
|
$Collage = $DB->to_array();
|
|
?>
|
|
<table class="layout recent" id="collage<?=$CollageID?>" cellpadding="0" cellspacing="0" border="0">
|
|
<tr class="colhead">
|
|
<td colspan="5">
|
|
<span style="float:left;">
|
|
<?=display_str($CName)?> - <a href="collages.php?id=<?=$CollageID?>">see full</a>
|
|
</span>
|
|
<span style="float:right;">
|
|
<a href="#" onclick="$('#collage<?=$CollageID?> .images').toggle(); this.innerHTML=(this.innerHTML=='(Hide)'?'(Show)':'(Hide)'); return false;"><?=$FirstCol?'(Hide)':'(Show)'?></a>
|
|
</span>
|
|
</td>
|
|
</tr>
|
|
<tr class="images <?=$FirstCol?'':' hidden'?>">
|
|
<? foreach($Collage as $C) {
|
|
$Group = get_groups(array($C['GroupID']));
|
|
$Group = array_pop($Group['matches']);
|
|
list($GroupID, $GroupName, $GroupYear, $GroupRecordLabel, $GroupCatalogueNumber, $TagList, $ReleaseType, $GroupVanityHouse, $Torrents, $GroupArtists) = array_values($Group);
|
|
|
|
$Name = '';
|
|
$Name .= display_artists(array('1'=>$GroupArtists), false, true);
|
|
$Name .= $GroupName;
|
|
?>
|
|
<td>
|
|
<a href="torrents.php?id=<?=$GroupID?>" title="<?=$Name?>"><img src="<?=to_thumbnail($C['WikiImage'])?>" alt="<?=$Name?>" width="107" /></a>
|
|
</td>
|
|
<? } ?>
|
|
</tr>
|
|
</table>
|
|
<?
|
|
$FirstCol = false;
|
|
}
|
|
|
|
|
|
|
|
// Linked accounts
|
|
if(check_perms('users_mod')) {
|
|
include(SERVER_ROOT.'/sections/user/linkedfunctions.php');
|
|
user_dupes_table($UserID);
|
|
}
|
|
|
|
if ((check_perms('users_view_invites')) && $Invited > 0) {
|
|
include(SERVER_ROOT.'/classes/class_invite_tree.php');
|
|
$Tree = new INVITE_TREE($UserID, array('visible'=>false));
|
|
?>
|
|
<div class="box">
|
|
<div class="head">Invite Tree <a href="#" onclick="$('#invitetree').toggle();return false;">(View)</a></div>
|
|
<div id="invitetree" class="hidden">
|
|
<? $Tree->make_tree(); ?>
|
|
</div>
|
|
</div>
|
|
<?
|
|
}
|
|
|
|
// Requests
|
|
if (check_paranoia_here('requestsvoted_list')) {
|
|
$DB->query("SELECT
|
|
r.ID,
|
|
r.CategoryID,
|
|
r.Title,
|
|
r.Year,
|
|
r.TimeAdded,
|
|
COUNT(rv.UserID) AS Votes,
|
|
SUM(rv.Bounty) AS Bounty
|
|
FROM requests AS r
|
|
LEFT JOIN users_main AS u ON u.ID=UserID
|
|
LEFT JOIN requests_votes AS rv ON rv.RequestID=r.ID
|
|
WHERE r.UserID = ".$UserID."
|
|
AND r.TorrentID = 0
|
|
GROUP BY r.ID
|
|
ORDER BY Votes DESC");
|
|
|
|
if($DB->record_count() > 0) {
|
|
$Requests = $DB->to_array();
|
|
?>
|
|
<div class="box">
|
|
<div class="head">Requests <a href="#" onclick="$('#requests').toggle();return false;">(View)</a></div>
|
|
<div id="requests" class="request_table hidden">
|
|
<table cellpadding="6" cellspacing="1" border="0" class="border" width="100%">
|
|
<tr class="colhead_dark">
|
|
<td style="width:48%;">
|
|
<strong>Request Name</strong>
|
|
</td>
|
|
<td>
|
|
<strong>Vote</strong>
|
|
</td>
|
|
<td>
|
|
<strong>Bounty</strong>
|
|
</td>
|
|
<td>
|
|
<strong>Added</strong>
|
|
</td>
|
|
</tr>
|
|
<?
|
|
foreach($Requests as $Request) {
|
|
list($RequestID, $CategoryID, $Title, $Year, $TimeAdded, $Votes, $Bounty) = $Request;
|
|
|
|
$Request = get_requests(array($RequestID));
|
|
$Request = $Request['matches'][$RequestID];
|
|
if(empty($Request)) {
|
|
continue;
|
|
}
|
|
|
|
list($RequestID, $RequestorID, $RequestorName, $TimeAdded, $LastVote, $CategoryID, $Title, $Year, $Image, $Description, $CatalogueNumber, $ReleaseType,
|
|
$BitrateList, $FormatList, $MediaList, $LogCue, $FillerID, $FillerName, $TorrentID, $TimeFilled) = $Request;
|
|
|
|
$CategoryName = $Categories[$CategoryID - 1];
|
|
|
|
if($CategoryName == "Music") {
|
|
$ArtistForm = get_request_artists($RequestID);
|
|
$ArtistLink = display_artists($ArtistForm, true, true);
|
|
$FullName = $ArtistLink."<a href='requests.php?action=view&id=".$RequestID."'>".$Title." [".$Year."]</a>";
|
|
} else if($CategoryName == "Audiobooks" || $CategoryName == "Comedy") {
|
|
$FullName = "<a href='requests.php?action=view&id=".$RequestID."'>".$Title." [".$Year."]</a>";
|
|
} else {
|
|
$FullName ="<a href='requests.php?action=view&id=".$RequestID."'>".$Title."</a>";
|
|
}
|
|
|
|
$Row = (empty($Row) || $Row == 'a') ? 'b' : 'a';
|
|
?>
|
|
<tr class="row<?=$Row?>">
|
|
<td>
|
|
<?=$FullName?>
|
|
<div class="tags">
|
|
<?
|
|
$Tags = $Request['Tags'];
|
|
$TagList = array();
|
|
foreach($Tags as $TagID => $TagName) {
|
|
$TagList[] = "<a href='requests.php?tags=".$TagName."'>".display_str($TagName)."</a>";
|
|
}
|
|
$TagList = implode(', ', $TagList);
|
|
?>
|
|
<?=$TagList?>
|
|
</div>
|
|
</td>
|
|
<td>
|
|
<span id="vote_count_<?=$RequestID?>"><?=$Votes?></span>
|
|
<? if(check_perms('site_vote')){ ?>
|
|
<input type="hidden" id="auth" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
|
<a href="javascript:Vote(0, <?=$RequestID?>)"><strong>(+)</strong></a>
|
|
<? } ?>
|
|
</td>
|
|
<td>
|
|
<span id="bounty_<?=$RequestID?>"><?=get_size($Bounty)?></span>
|
|
</td>
|
|
<td>
|
|
<?=time_diff($TimeAdded)?>
|
|
</td>
|
|
</tr>
|
|
<? } ?>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
<?
|
|
}
|
|
}
|
|
|
|
$IsFLS = $LoggedUser['ExtraClasses'][41];
|
|
if (check_perms('users_mod', $Class) || $IsFLS) {
|
|
$UserLevel = $LoggedUser['EffectiveClass'];
|
|
$DB->query("SELECT
|
|
SQL_CALC_FOUND_ROWS
|
|
ID,
|
|
Subject,
|
|
Status,
|
|
Level,
|
|
AssignedToUser,
|
|
Date,
|
|
ResolverID
|
|
FROM staff_pm_conversations
|
|
WHERE UserID = $UserID AND (Level <= $UserLevel OR AssignedToUser='".$LoggedUser['ID']."')
|
|
ORDER BY Date DESC");
|
|
if ($DB->record_count()) {
|
|
$StaffPMs = $DB->to_array();
|
|
?>
|
|
<div class="box">
|
|
<div class="head">Staff PMs <a href="#" onclick="$('#staffpms').toggle();return false;">(View)</a></div>
|
|
<table width="100%" class="message_table hidden" id="staffpms">
|
|
<tr class="colhead">
|
|
<td>Subject</td>
|
|
<td>Date</td>
|
|
<td>Assigned To</td>
|
|
<td>Resolved By</td>
|
|
</tr>
|
|
<? foreach($StaffPMs as $StaffPM) {
|
|
list($ID, $Subject, $Status, $Level, $AssignedTo, $Date, $ResolverID) = $StaffPM;
|
|
// Get assigned
|
|
if ($AssignedToUser == '') {
|
|
// Assigned to class
|
|
$Assigned = ($Level == 0) ? "First Line Support" : $ClassLevels[$Level]['Name'];
|
|
// No + on Sysops
|
|
if ($Assigned != 'Sysop') { $Assigned .= "+"; }
|
|
|
|
} else {
|
|
// Assigned to user
|
|
$Assigned = format_username($UserID, true, true, true, true);
|
|
}
|
|
|
|
if ($ResolverID) {
|
|
$Resolver = format_username($ResolverID, true, true, true, true);
|
|
} else {
|
|
$Resolver = "(unresolved)";
|
|
}
|
|
|
|
?>
|
|
<tr>
|
|
<td><a href="staffpm.php?action=viewconv&id=<?=$ID?>"><?=display_str($Subject)?></a></td>
|
|
<td><?=time_diff($Date, 2, true)?></td>
|
|
<td><?=$Assigned?></td>
|
|
<td><?=$Resolver?></td>
|
|
</tr>
|
|
<? } ?>
|
|
</table>
|
|
</div>
|
|
<? }
|
|
}
|
|
?>
|
|
<br />
|
|
<?
|
|
|
|
if($LoggedUser['Class'] == 650 && check_perms('users_warn', $Class)) {
|
|
$DB->query("SELECT Comment FROM users_warnings_forums WHERE UserID = '$UserID'");
|
|
list($ForumWarnings) = $DB->next_record();
|
|
if($DB->record_count() > 0) {
|
|
?>
|
|
<div class="box">
|
|
<div class="head">Forum Warnings</div>
|
|
<div class="pad">
|
|
<div id="forumwarningslinks" class="AdminComment box" style="width:98%;"><?=$Text->full_format($ForumWarnings)?></div>
|
|
</div>
|
|
</div>
|
|
<br />
|
|
<?
|
|
}
|
|
}
|
|
if (check_perms('users_mod', $Class)) { ?>
|
|
<form class="manage_form" name="user" id="form" action="user.php" method="post">
|
|
<input type="hidden" name="action" value="moderate" />
|
|
<input type="hidden" name="userid" value="<?=$UserID?>" />
|
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
|
|
|
<div class="box">
|
|
<div class="head">Staff Notes <a href="#" name="admincommentbutton" onclick="ChangeTo('text'); return false;">(Edit)</a></div>
|
|
<div class="pad">
|
|
<input type="hidden" name="comment_hash" value="<?=$CommentHash?>" />
|
|
<div id="admincommentlinks" class="AdminComment box" style="width:98%;"><?=$Text->full_format($AdminComment)?></div>
|
|
<textarea id="admincomment" onkeyup="resize('admincomment');" class="AdminComment hidden" name="AdminComment" cols="65" rows="26" style="width:98%;"><?=display_str($AdminComment)?></textarea>
|
|
<a href="#" name="admincommentbutton" onclick="ChangeTo('text'); return false;">Toggle Edit</a>
|
|
<script type="text/javascript">
|
|
resize('admincomment');
|
|
</script>
|
|
</div>
|
|
</div>
|
|
|
|
<table class="layout">
|
|
<tr class="colhead">
|
|
<td colspan="2">User Info</td>
|
|
</tr>
|
|
<? if (check_perms('users_edit_usernames', $Class)) { ?>
|
|
<tr>
|
|
<td class="label">Username:</td>
|
|
<td><input type="text" size="20" name="Username" value="<?=display_str($Username)?>" /></td>
|
|
</tr>
|
|
<?
|
|
}
|
|
if (check_perms('users_edit_titles')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Custom Title:</td>
|
|
<td><input type="text" size="50" name="Title" value="<?=display_str($CustomTitle)?>" /></td>
|
|
</tr>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_promote_below', $Class) || check_perms('users_promote_to', $Class-1)) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Class:</td>
|
|
<td>
|
|
<select name="Class">
|
|
<?
|
|
foreach ($ClassLevels as $CurClass) {
|
|
if (check_perms('users_promote_below', $Class) && $CurClass['ID']>=$LoggedUser['EffectiveClass']) { break; }
|
|
if ($CurClass['ID']>$LoggedUser['EffectiveClass']) { break; }
|
|
if ($CurClass['Secondary']) { continue; }
|
|
if ($Class===$CurClass['Level']) { $Selected='selected="selected"'; } else { $Selected=""; }
|
|
?>
|
|
<option value="<?=$CurClass['ID']?>" <?=$Selected?>><?=$CurClass['Name'].' ('.$CurClass['Level'].')'?></option>
|
|
<? } ?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_give_donor')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Donor:</td>
|
|
<td><input type="checkbox" name="Donor" <? if ($Donor == 1) { ?>checked="checked" <? } ?> /></td>
|
|
</tr>
|
|
<?
|
|
}
|
|
if (check_perms('users_promote_below') || check_perms('users_promote_to')) { ?>
|
|
<tr>
|
|
<td class="label">Secondary Classes:</td>
|
|
<td>
|
|
<?
|
|
$DB->query("SELECT p.ID, p.Name, l.UserID
|
|
FROM permissions AS p
|
|
LEFT JOIN users_levels AS l ON l.PermissionID = p.ID AND l.UserID = '$UserID'
|
|
WHERE p.Secondary = 1
|
|
ORDER BY p.Name");
|
|
$i = 0;
|
|
while (list($PermID, $PermName, $IsSet) = $DB->next_record()) {
|
|
$i++;
|
|
?>
|
|
<input type="checkbox" id="perm_<?=$PermID?>" name="secondary_classes[]" value="<?=$PermID?>" <? if ($IsSet) { ?>checked="checked" <? } ?> /> <label for="perm_<?=$PermID?>" style="margin-right: 10px;"><?=$PermName?></label>
|
|
<? if ($i % 5 == 0) { echo '<br />'; }
|
|
} ?>
|
|
</td>
|
|
</tr>
|
|
<? }
|
|
if (check_perms('users_make_invisible')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Visible:</td>
|
|
<td><input type="checkbox" name="Visible" <? if ($Visible == 1) { ?>checked="checked" <? } ?> /></td>
|
|
</tr>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_edit_ratio',$Class) || (check_perms('users_edit_own_ratio') && $UserID == $LoggedUser['ID'])) {
|
|
?>
|
|
<tr>
|
|
<td class="label"><span title="Upload amount in bytes. Also accepts e.g. +20GB or -35.6364MB on the end">Uploaded:</span></td>
|
|
<td>
|
|
<input type="hidden" name="OldUploaded" value="<?=$Uploaded?>" />
|
|
<input type="text" size="20" name="Uploaded" value="<?=$Uploaded?>" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label"><span title="Download amount in bytes. Also accepts e.g. +20GB or -35.6364MB on the end">Downloaded:</span></td>
|
|
<td>
|
|
<input type="hidden" name="OldDownloaded" value="<?=$Downloaded?>" />
|
|
<input type="text" size="20" name="Downloaded" value="<?=$Downloaded?>" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">Merge Stats <strong>From:</strong></td>
|
|
<td>
|
|
<input type="text" size="40" name="MergeStatsFrom" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">Freeleech Tokens:</td>
|
|
<td>
|
|
<input type="text" size="5" name="FLTokens" value="<?=$FLTokens?>" />
|
|
</td>
|
|
</tr>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_edit_invites')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Invites:</td>
|
|
<td><input type="text" size="5" name="Invites" value="<?=$Invites?>" /></td>
|
|
</tr>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('admin_manage_fls') || (check_perms('users_mod') && $OwnProfile)) {
|
|
?>
|
|
<tr>
|
|
<td class="label">First Line Support:</td>
|
|
<td><input type="text" size="50" name="SupportFor" value="<?=display_str($SupportFor)?>" /></td>
|
|
</tr>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_edit_reset_keys')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Reset:</td>
|
|
<td>
|
|
<input type="checkbox" name="ResetRatioWatch" id="ResetRatioWatch" /> <label for="ResetRatioWatch">Ratio Watch</label> |
|
|
<input type="checkbox" name="ResetPasskey" id="ResetPasskey" /> <label for="ResetPasskey">Passkey</label> |
|
|
<input type="checkbox" name="ResetAuthkey" id="ResetAuthkey" /> <label for="ResetAuthkey">Authkey</label> |
|
|
<input type="checkbox" name="ResetIPHistory" id="ResetIPHistory" /> <label for="ResetIPHistory">IP History</label> |
|
|
<input type="checkbox" name="ResetEmailHistory" id="ResetEmailHistory" /> <label for="ResetEmailHistory">Email History</label>
|
|
<br />
|
|
<input type="checkbox" name="ResetSnatchList" id="ResetSnatchList" /> <label for="ResetSnatchList">Snatch List</label> |
|
|
<input type="checkbox" name="ResetDownloadList" id="ResetDownloadList" /> <label for="ResetDownloadList">Download List</label>
|
|
</td>
|
|
</tr>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_mod')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Reset all EAC v0.95 Logs To:</td>
|
|
<td>
|
|
<select name="095logs">
|
|
<option value=""></option>
|
|
<option value="99">99</option>
|
|
<option value="100">100</option>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<? }
|
|
|
|
if (check_perms('users_edit_password')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">New Password:</td>
|
|
<td>
|
|
<input type="text" size="30" id="change_password" name="ChangePassword" />
|
|
</td>
|
|
</tr>
|
|
<? } ?>
|
|
</table><br />
|
|
|
|
<? if (check_perms('users_warn')) { ?>
|
|
<table class="layout">
|
|
<tr class="colhead">
|
|
<td colspan="2">Warn User</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">Warned:</td>
|
|
<td>
|
|
<input type="checkbox" name="Warned" <? if ($Warned != '0000-00-00 00:00:00') { ?>checked="checked"<? } ?> />
|
|
</td>
|
|
</tr>
|
|
<? if ($Warned=='0000-00-00 00:00:00') { // user is not warned ?>
|
|
<tr>
|
|
<td class="label">Expiration:</td>
|
|
<td>
|
|
<select name="WarnLength">
|
|
<option value="">---</option>
|
|
<option value="1"> 1 Week</option>
|
|
<option value="2"> 2 Weeks</option>
|
|
<option value="4"> 4 Weeks</option>
|
|
<option value="8"> 8 Weeks</option>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<? } else { // user is warned ?>
|
|
<tr>
|
|
<td class="label">Extension:</td>
|
|
<td>
|
|
<select name="ExtendWarning" onchange="ToggleWarningAdjust(this)">
|
|
<option>---</option>
|
|
<option value="1"> 1 Week</option>
|
|
<option value="2"> 2 Weeks</option>
|
|
<option value="4"> 4 Weeks</option>
|
|
<option value="8"> 8 Weeks</option>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<tr id="ReduceWarningTR">
|
|
<td class="label">Reduction:</td>
|
|
<td>
|
|
<select name="ReduceWarning">
|
|
<option>---</option>
|
|
<option value="1"> 1 Week</option>
|
|
<option value="2"> 2 Weeks</option>
|
|
<option value="4"> 4 Weeks</option>
|
|
<option value="8"> 8 Weeks</option>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<? } ?>
|
|
<tr>
|
|
<td class="label">Reason:</td>
|
|
<td>
|
|
<input type="text" size="60" name="WarnReason" />
|
|
</td>
|
|
</tr>
|
|
<? } ?>
|
|
</table><br />
|
|
<table class="layout">
|
|
<tr class="colhead"><td colspan="2">User Privileges</td></tr>
|
|
<? if (check_perms('users_disable_posts') || check_perms('users_disable_any')) {
|
|
$DB->query("SELECT DISTINCT Email, IP FROM users_history_emails WHERE UserID = ".$UserID." ORDER BY Time ASC");
|
|
$Emails = $DB->to_array();
|
|
?>
|
|
<tr>
|
|
<td class="label">Disable:</td>
|
|
<td>
|
|
<input type="checkbox" name="DisablePosting" id="DisablePosting"<? if ($DisablePosting==1) { ?>checked="checked"<? } ?> /> <label for="DisablePosting">Posting</label>
|
|
<? if (check_perms('users_disable_any')) { ?> |
|
|
<input type="checkbox" name="DisableAvatar" id="DisableAvatar"<? if ($DisableAvatar==1) { ?>checked="checked"<? } ?> /> <label for="DisableAvatar">Avatar</label> |
|
|
<input type="checkbox" name="DisableInvites" id="DisableInvites"<? if ($DisableInvites==1) { ?>checked="checked"<? } ?> /> <label for="DisableInvites">Invites</label> |
|
|
|
|
<input type="checkbox" name="DisableForums" id="DisableForums"<? if ($DisableForums==1) { ?>checked="checked"<? } ?> /> <label for="DisableForums">Forums</label> |
|
|
<input type="checkbox" name="DisableTagging" id="DisableTagging"<? if ($DisableTagging==1) { ?>checked="checked"<? } ?> /> <label for="DisableTagging">Tagging</label> |
|
|
<input type="checkbox" name="DisableRequests" id="DisableRequests"<? if ($DisableRequests==1) { ?>checked="checked"<? } ?> /> <label for="DisableRequests">Requests</label>
|
|
<br />
|
|
<input type="checkbox" name="DisableUpload" id="DisableUpload"<? if ($DisableUpload==1) { ?>checked="checked"<? } ?> /> <label for="DisableUpload">Upload</label> |
|
|
<input type="checkbox" name="DisableWiki" id="DisableWiki"<? if ($DisableWiki==1) { ?>checked="checked"<? } ?> /> <label for="DisableWiki">Wiki</label> |
|
|
<input type="checkbox" name="DisableLeech" id="DisableLeech"<? if ($DisableLeech==0) { ?>checked="checked"<? } ?> /> <label for="DisableLeech">Leech</label> |
|
|
<input type="checkbox" name="DisablePM" id="DisablePM"<? if ($DisablePM==1) { ?>checked="checked"<? } ?> /> <label for="DisablePM">PM</label> |
|
|
<input type="checkbox" name="DisableIRC" id="DisableIRC"<? if ($DisableIRC==1) { ?>checked="checked"<? } ?> /> <label for="DisableIRC">IRC</label>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">Hacked:</td>
|
|
<td>
|
|
<input type="checkbox" name="SendHackedMail" id="SendHackedMail" /> <label for="SendHackedMail">Send hacked account email</label> to
|
|
<select name="HackedEmail">
|
|
<?
|
|
foreach($Emails as $Email) {
|
|
list($Address, $IP) = $Email;
|
|
?>
|
|
<option value="<?=display_str($Address)?>"><?=display_str($Address)?> - <?=display_str($IP)?></option>
|
|
<? } ?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
|
|
<? } ?>
|
|
<?
|
|
}
|
|
|
|
if (check_perms('users_disable_any')) {
|
|
?>
|
|
<tr>
|
|
<td class="label">Account:</td>
|
|
<td>
|
|
<select name="UserStatus">
|
|
<option value="0" <? if ($Enabled=='0') { ?>selected="selected"<? } ?>>Unconfirmed</option>
|
|
<option value="1" <? if ($Enabled=='1') { ?>selected="selected"<? } ?>>Enabled</option>
|
|
<option value="2" <? if ($Enabled=='2') { ?>selected="selected"<? } ?>>Disabled</option>
|
|
<? if (check_perms('users_delete_users')) { ?>
|
|
<optgroup label="-- WARNING --"></optgroup>
|
|
<option value="delete">Delete Account</option>
|
|
<? } ?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">User Reason:</td>
|
|
<td>
|
|
<input type="text" size="60" name="UserReason" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">Restricted Forums (comma-delimited):</td>
|
|
<td>
|
|
<input type="text" size="60" name="RestrictedForums" value="<?=display_str($RestrictedForums)?>" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">Extra Forums (comma-delimited):</td>
|
|
<td>
|
|
<input type="text" size="60" name="PermittedForums" value="<?=display_str($PermittedForums)?>" />
|
|
</td>
|
|
</tr>
|
|
|
|
<? } ?>
|
|
</table><br />
|
|
<? if(check_perms('users_logout')) { ?>
|
|
<table class="layout">
|
|
<tr class="colhead"><td colspan="2">Session</td></tr>
|
|
<tr>
|
|
<td class="label">Reset session:</td>
|
|
<td><input type="checkbox" name="ResetSession" id="ResetSession" /></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label">Log out:</td>
|
|
<td><input type="checkbox" name="LogOut" id="LogOut" /></td>
|
|
</tr>
|
|
|
|
</table>
|
|
<? } ?>
|
|
<table class="layout">
|
|
<tr class="colhead"><td colspan="2">Submit</td></tr>
|
|
<tr>
|
|
<td class="label">Reason:</td>
|
|
<td>
|
|
<textarea rows="1" cols="50" name="Reason" id="Reason" onkeyup="resize('Reason');"></textarea>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td align="right" colspan="2">
|
|
<input type="submit" value="Save Changes" />
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</form>
|
|
<? } ?>
|
|
</div>
|
|
</div>
|
|
<? show_footer(); ?>
|