mirror of
https://github.com/WhatCD/Gazelle.git
synced 2025-01-18 12:11:36 +00:00
Empty commit
This commit is contained in:
parent
69c8524bff
commit
e78e066207
@ -83,7 +83,7 @@ public static function all_bookmarks($Type, $UserID = false) {
|
|||||||
$UserID = $LoggedUser['ID'];
|
$UserID = $LoggedUser['ID'];
|
||||||
}
|
}
|
||||||
$CacheKey = 'bookmarks_' . $Type . '_' . $UserID;
|
$CacheKey = 'bookmarks_' . $Type . '_' . $UserID;
|
||||||
if (($Bookmarks = $Cache->get_value($CacheKey)) === FALSE) {
|
if (($Bookmarks = $Cache->get_value($CacheKey)) === false) {
|
||||||
list ($Table, $Col) = self::bookmark_schema($Type);
|
list ($Table, $Col) = self::bookmark_schema($Type);
|
||||||
$DB->query("SELECT $Col FROM $Table WHERE UserID = '$UserID'");
|
$DB->query("SELECT $Col FROM $Table WHERE UserID = '$UserID'");
|
||||||
$Bookmarks = $DB->collect($Col);
|
$Bookmarks = $DB->collect($Col);
|
||||||
|
@ -91,10 +91,10 @@ public function get_cpu_time() {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function log_var($Var, $VarName = FALSE) {
|
public function log_var($Var, $VarName = false) {
|
||||||
$BackTrace = debug_backtrace();
|
$BackTrace = debug_backtrace();
|
||||||
$ID = uniqid();
|
$ID = uniqid();
|
||||||
if(!$VarName) {
|
if (!$VarName) {
|
||||||
$VarName = $ID;
|
$VarName = $ID;
|
||||||
}
|
}
|
||||||
$File = array('path' => substr($BackTrace[0]['file'], strlen(SERVER_ROOT)), 'line' => $BackTrace[0]['line']);
|
$File = array('path' => substr($BackTrace[0]['file'], strlen(SERVER_ROOT)), 'line' => $BackTrace[0]['line']);
|
||||||
@ -103,7 +103,7 @@ public function log_var($Var, $VarName = FALSE) {
|
|||||||
|
|
||||||
public function set_flag($Event) {
|
public function set_flag($Event) {
|
||||||
global $ScriptStartTime;
|
global $ScriptStartTime;
|
||||||
$this->Flags[] = array($Event, (microtime(true)-$ScriptStartTime)*1000, memory_get_usage(true), $this->get_cpu_time());
|
$this->Flags[] = array($Event, (microtime(true) - $ScriptStartTime) * 1000, memory_get_usage(true), $this->get_cpu_time());
|
||||||
}
|
}
|
||||||
|
|
||||||
//This isn't in the constructor because $this is not available, and the function cannot be made static
|
//This isn't in the constructor because $this is not available, and the function cannot be made static
|
||||||
@ -118,7 +118,7 @@ protected function format_args($Array) {
|
|||||||
$Return = array();
|
$Return = array();
|
||||||
foreach ($Array as $Key => $Val) {
|
foreach ($Array as $Key => $Val) {
|
||||||
$Return[$Key] = '';
|
$Return[$Key] = '';
|
||||||
if (!is_int($Key) || $Key != $LastKey+1) {
|
if (!is_int($Key) || $Key != $LastKey + 1) {
|
||||||
$Return[$Key] .= "'$Key' => ";
|
$Return[$Key] .= "'$Key' => ";
|
||||||
}
|
}
|
||||||
if ($Val === true) {
|
if ($Val === true) {
|
||||||
@ -194,7 +194,7 @@ public function php_error_handler($Level, $Error, $File, $Line) {
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
//Hiding "session_start(): Server 10.10.0.1 (tcp 11211) failed with: No route to host (113)" errors
|
//Hiding "session_start(): Server 10.10.0.1 (tcp 11211) failed with: No route to host (113)" errors
|
||||||
if($Call != "session_start") {
|
if ($Call != "session_start") {
|
||||||
$this->Errors[] = array($Error, $File.':'.$Line, $Call, $Args);
|
$this->Errors[] = array($Error, $File.':'.$Line, $Call, $Args);
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
@ -277,13 +277,13 @@ public function get_sphinx_time() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function get_sphinxql_queries() {
|
public function get_sphinxql_queries() {
|
||||||
if(class_exists('Sphinxql')) {
|
if (class_exists('Sphinxql')) {
|
||||||
return Sphinxql::$Queries;
|
return Sphinxql::$Queries;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_sphinxql_time() {
|
public function get_sphinxql_time() {
|
||||||
if(class_exists('Sphinxql')) {
|
if (class_exists('Sphinxql')) {
|
||||||
return Sphinxql::$Time;
|
return Sphinxql::$Time;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -314,7 +314,7 @@ public function perf_table($Perf=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_perf').toggle();return false;">(View)</a> Performance stats:</strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_perf').toggle();return false;" class="brackets">View</a> Performance stats:</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_perf" class="debug_table hidden" width="100%">
|
<table id="debug_perf" class="debug_table hidden" width="100%">
|
||||||
@ -339,7 +339,7 @@ public function include_table($Includes=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_include').toggle();return false;">(View)</a> <?=number_format(count($Includes))?> Includes:</strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_include').toggle();return false;" class="brackets">View</a> <?=number_format(count($Includes))?> Includes:</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_include" class="debug_table hidden" width="100%">
|
<table id="debug_include" class="debug_table hidden" width="100%">
|
||||||
@ -363,7 +363,7 @@ public function class_table($Classes=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_classes').toggle();return false;">(View)</a> Classes:</strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_classes').toggle();return false;" class="brackets">View</a> Classes:</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_classes" class="debug_table hidden" width="100%">
|
<table id="debug_classes" class="debug_table hidden" width="100%">
|
||||||
@ -380,7 +380,7 @@ public function extension_table() {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_extensions').toggle();return false;">(View)</a> Extensions:</strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_extensions').toggle();return false;" class="brackets">View</a> Extensions:</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_extensions" class="debug_table hidden" width="100%">
|
<table id="debug_extensions" class="debug_table hidden" width="100%">
|
||||||
@ -403,7 +403,7 @@ public function flag_table($Flags=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_flags').toggle();return false;">(View)</a> Flags:</strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_flags').toggle();return false;" class="brackets">View</a> Flags:</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_flags" class="debug_table hidden" width="100%">
|
<table id="debug_flags" class="debug_table hidden" width="100%">
|
||||||
@ -441,7 +441,7 @@ public function constant_table($Constants=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_constants').toggle();return false;">(View)</a> Constants:</strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_constants').toggle();return false;" class="brackets">View</a> Constants:</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_constants" class="debug_table hidden" width="100%">
|
<table id="debug_constants" class="debug_table hidden" width="100%">
|
||||||
@ -469,11 +469,11 @@ public function cache_table($CacheKeys=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_cache').toggle();return false;">(View)</a><?=$Header?></strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_cache').toggle();return false;" class="brackets">View</a><?=$Header?></strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_cache" class="debug_table hidden" width="100%">
|
<table id="debug_cache" class="debug_table hidden" width="100%">
|
||||||
<? foreach($CacheKeys as $Key) { ?>
|
<? foreach ($CacheKeys as $Key) { ?>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left" class="debug_info debug_cache_key">
|
<td align="left" class="debug_info debug_cache_key">
|
||||||
<a href="#" onclick="$('#debug_cache_<?=$Key?>').toggle(); return false;"><?=display_str($Key)?></a>
|
<a href="#" onclick="$('#debug_cache_<?=$Key?>').toggle(); return false;"><?=display_str($Key)?></a>
|
||||||
@ -497,7 +497,7 @@ public function error_table($Errors=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_error').toggle();return false;">(View)</a> <?=number_format(count($Errors))?> Errors:</strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_error').toggle();return false;" class="brackets">View</a> <?=number_format(count($Errors))?> Errors:</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_error" class="debug_table hidden" width="100%">
|
<table id="debug_error" class="debug_table hidden" width="100%">
|
||||||
@ -536,7 +536,7 @@ public function query_table($Queries=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_database').toggle();return false;">(View)</a><?=$Header?></strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_database').toggle();return false;" class="brackets">View</a><?=$Header?></strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_database" class="debug_table hidden" width="100%">
|
<table id="debug_database" class="debug_table hidden" width="100%">
|
||||||
@ -546,7 +546,7 @@ public function query_table($Queries=false) {
|
|||||||
?>
|
?>
|
||||||
<tr valign="top">
|
<tr valign="top">
|
||||||
<td class="debug_data debug_query_data"><div><?=str_replace("\t", ' ', nl2br(display_str($SQL)))?></div></td>
|
<td class="debug_data debug_query_data"><div><?=str_replace("\t", ' ', nl2br(display_str($SQL)))?></div></td>
|
||||||
<td class="rowa debug_info debug_query_time" style="width:130px;" align="left"><?=number_format($Time, 5)?> ms</td>
|
<td class="rowa debug_info debug_query_time" style="width: 130px;" align="left"><?=number_format($Time, 5)?> ms</td>
|
||||||
</tr>
|
</tr>
|
||||||
<?
|
<?
|
||||||
}
|
}
|
||||||
@ -559,10 +559,10 @@ public function sphinx_table($Queries=false) {
|
|||||||
$Header = 'Searches';
|
$Header = 'Searches';
|
||||||
if (!is_array($Queries)) {
|
if (!is_array($Queries)) {
|
||||||
$Queries = $this->get_sphinx_queries();
|
$Queries = $this->get_sphinx_queries();
|
||||||
if($QueriesQL = $this->get_sphinxql_queries()) {
|
if ($QueriesQL = $this->get_sphinxql_queries()) {
|
||||||
$Queries = array_merge($Queries, $QueriesQL);
|
$Queries = array_merge($Queries, $QueriesQL);
|
||||||
}
|
}
|
||||||
$Header .= ' ('.number_format($this->get_sphinx_time()+$this->get_sphinxql_time(), 5).' ms)';
|
$Header .= ' ('.number_format($this->get_sphinx_time() + $this->get_sphinxql_time(), 5).' ms)';
|
||||||
}
|
}
|
||||||
if (empty($Queries)) {
|
if (empty($Queries)) {
|
||||||
return;
|
return;
|
||||||
@ -571,7 +571,7 @@ public function sphinx_table($Queries=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_sphinx').toggle();return false;">(View)</a><?=$Header?></strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_sphinx').toggle();return false;" class="brackets">View</a><?=$Header?></strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_sphinx" class="debug_table hidden" width="100%">
|
<table id="debug_sphinx" class="debug_table hidden" width="100%">
|
||||||
@ -581,7 +581,7 @@ public function sphinx_table($Queries=false) {
|
|||||||
?>
|
?>
|
||||||
<tr valign="top">
|
<tr valign="top">
|
||||||
<td class="debug_data debug_sphinx_data"><pre><?=str_replace("\t", ' ', $Params)?></pre></td>
|
<td class="debug_data debug_sphinx_data"><pre><?=str_replace("\t", ' ', $Params)?></pre></td>
|
||||||
<td class="rowa debug_info debug_sphinx_time" style="width:130px;" align="left"><?=number_format($Time, 5)?> ms</td>
|
<td class="rowa debug_info debug_sphinx_time" style="width: 130px;" align="left"><?=number_format($Time, 5)?> ms</td>
|
||||||
</tr>
|
</tr>
|
||||||
<?
|
<?
|
||||||
}
|
}
|
||||||
@ -593,7 +593,7 @@ public function sphinx_table($Queries=false) {
|
|||||||
public function vars_table($Vars=false) {
|
public function vars_table($Vars=false) {
|
||||||
$Header = 'Logged Variables';
|
$Header = 'Logged Variables';
|
||||||
if (empty($Vars)) {
|
if (empty($Vars)) {
|
||||||
if(empty($this->LoggedVars)) {
|
if (empty($this->LoggedVars)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$Vars = $this->LoggedVars;
|
$Vars = $this->LoggedVars;
|
||||||
@ -603,12 +603,12 @@ public function vars_table($Vars=false) {
|
|||||||
?>
|
?>
|
||||||
<table class="layout" width="100%">
|
<table class="layout" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td align="left"><strong><a href="#" onclick="$('#debug_loggedvars').toggle();return false;">(View)</a><?=$Header?></strong></td>
|
<td align="left"><strong><a href="#" onclick="$('#debug_loggedvars').toggle();return false;" class="brackets">View</a><?=$Header?></strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table id="debug_loggedvars" class="debug_table hidden" width="100%">
|
<table id="debug_loggedvars" class="debug_table hidden" width="100%">
|
||||||
<?
|
<?
|
||||||
foreach($Vars as $ID => $Var) {
|
foreach ($Vars as $ID => $Var) {
|
||||||
list($Key, $Data) = each($Var);
|
list($Key, $Data) = each($Var);
|
||||||
$Size = count($Data['data']);
|
$Size = count($Data['data']);
|
||||||
?>
|
?>
|
||||||
|
@ -72,8 +72,7 @@ class MASS_USER_TORRENTS_TABLE_VIEW
|
|||||||
* @param string $EditType
|
* @param string $EditType
|
||||||
* @param string $Heading
|
* @param string $Heading
|
||||||
*/
|
*/
|
||||||
public function __construct (array &$TorrentList, array &$CollageDataList, $EditType, $Heading = null)
|
public function __construct (array &$TorrentList, array &$CollageDataList, $EditType, $Heading = null) {
|
||||||
{
|
|
||||||
global $UserID, $LoggedUser;
|
global $UserID, $LoggedUser;
|
||||||
|
|
||||||
$this->set_heading($Heading);
|
$this->set_heading($Heading);
|
||||||
@ -86,11 +85,12 @@ public function __construct (array &$TorrentList, array &$CollageDataList, $Edit
|
|||||||
$this->CollageDataList = $CollageDataList;
|
$this->CollageDataList = $CollageDataList;
|
||||||
|
|
||||||
$this->HasTorrents = !empty($TorrentList);
|
$this->HasTorrents = !empty($TorrentList);
|
||||||
if(!$this->HasTorrents) $this->no_torrents();
|
if (!$this->HasTorrents) {
|
||||||
|
$this->no_torrents();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private function no_torrents ()
|
private function no_torrents () {
|
||||||
{
|
|
||||||
?>
|
?>
|
||||||
<div class="thin">
|
<div class="thin">
|
||||||
<div class="header">
|
<div class="header">
|
||||||
@ -106,8 +106,7 @@ private function no_torrents ()
|
|||||||
/**
|
/**
|
||||||
* Renders a complete page and table
|
* Renders a complete page and table
|
||||||
*/
|
*/
|
||||||
public function render_all ()
|
public function render_all () {
|
||||||
{
|
|
||||||
$this->header();
|
$this->header();
|
||||||
$this->body();
|
$this->body();
|
||||||
$this->footer();
|
$this->footer();
|
||||||
@ -117,8 +116,7 @@ public function render_all ()
|
|||||||
* Renders a comptele page/table header: div#thin, h2, scripts, notes,
|
* Renders a comptele page/table header: div#thin, h2, scripts, notes,
|
||||||
* form, table, etc.
|
* form, table, etc.
|
||||||
*/
|
*/
|
||||||
public function header ()
|
public function header () {
|
||||||
{
|
|
||||||
if ($this->HasTorrents) :
|
if ($this->HasTorrents) :
|
||||||
?>
|
?>
|
||||||
|
|
||||||
@ -149,13 +147,13 @@ public function header ()
|
|||||||
<table id="manage_collage_table">
|
<table id="manage_collage_table">
|
||||||
<thead>
|
<thead>
|
||||||
<tr class="colhead">
|
<tr class="colhead">
|
||||||
<th style="width:7%">Order</th>
|
<th style="width: 7%">Order</th>
|
||||||
<th style="width:1%"><span><abbr title="Current order">#</abbr></span></th>
|
<th style="width: 1%"><span><abbr title="Current order">#</abbr></span></th>
|
||||||
<th style="width:1%"><span>Year</span></th>
|
<th style="width: 1%"><span>Year</span></th>
|
||||||
<th style="width:15%"><span>Artist</span></th>
|
<th style="width: 15%"><span>Artist</span></th>
|
||||||
<th><span>Torrent</span></th>
|
<th><span>Torrent</span></th>
|
||||||
<th style="width:5%"><span>Bookmarked</span></th>
|
<th style="width: 5%"><span>Bookmarked</span></th>
|
||||||
<th style="width:1%" id="check_all"><span>Remove</span></th>
|
<th style="width: 1%" id="check_all"><span>Remove</span></th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
@ -166,8 +164,7 @@ public function header ()
|
|||||||
/**
|
/**
|
||||||
* Closes header code
|
* Closes header code
|
||||||
*/
|
*/
|
||||||
public function footer ()
|
public function footer () {
|
||||||
{
|
|
||||||
if ($this->HasTorrents) :
|
if ($this->HasTorrents) :
|
||||||
?>
|
?>
|
||||||
|
|
||||||
@ -192,8 +189,7 @@ public function footer ()
|
|||||||
* Formats data for use in row
|
* Formats data for use in row
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public function body ()
|
public function body () {
|
||||||
{
|
|
||||||
if ($this->HasTorrents)
|
if ($this->HasTorrents)
|
||||||
foreach ($this->TorrentList as $GroupID => $Group) {
|
foreach ($this->TorrentList as $GroupID => $Group) {
|
||||||
$Artists = array();
|
$Artists = array();
|
||||||
@ -221,8 +217,7 @@ public function body ()
|
|||||||
* @param string $DisplayName
|
* @param string $DisplayName
|
||||||
* @param string $TorrentLink
|
* @param string $TorrentLink
|
||||||
*/
|
*/
|
||||||
public function row ($Sort, $GroupID, $GroupYear, $DisplayName, $TorrentLink, $DateAdded)
|
public function row ($Sort, $GroupID, $GroupYear, $DisplayName, $TorrentLink, $DateAdded) {
|
||||||
{
|
|
||||||
$CSS = $this->NumGroups % 2 === 0 ? 'rowa' : 'rowb';
|
$CSS = $this->NumGroups % 2 === 0 ? 'rowa' : 'rowb';
|
||||||
?>
|
?>
|
||||||
|
|
||||||
@ -248,8 +243,7 @@ public function row ($Sort, $GroupID, $GroupYear, $DisplayName, $TorrentLink, $D
|
|||||||
* @param string $VanityHouse
|
* @param string $VanityHouse
|
||||||
* @return string $DisplayName
|
* @return string $DisplayName
|
||||||
*/
|
*/
|
||||||
static public function display_name (array &$ExtendedArtists, array &$Artists, $VanityHouse)
|
static public function display_name (array &$ExtendedArtists, array &$Artists, $VanityHouse) {
|
||||||
{
|
|
||||||
$DisplayName = '';
|
$DisplayName = '';
|
||||||
if (!empty($ExtendedArtists[1]) || !empty($ExtendedArtists[4])
|
if (!empty($ExtendedArtists[1]) || !empty($ExtendedArtists[4])
|
||||||
|| !empty($ExtendedArtists[5]) || !empty($ExtendedArtists[6])) {
|
|| !empty($ExtendedArtists[5]) || !empty($ExtendedArtists[6])) {
|
||||||
@ -265,8 +259,7 @@ static public function display_name (array &$ExtendedArtists, array &$Artists, $
|
|||||||
/**
|
/**
|
||||||
* Renders buttons used at the top and bottom of the table
|
* Renders buttons used at the top and bottom of the table
|
||||||
*/
|
*/
|
||||||
public function buttons ()
|
public function buttons () {
|
||||||
{
|
|
||||||
?>
|
?>
|
||||||
<div class="drag_drop_save">
|
<div class="drag_drop_save">
|
||||||
<input type="submit" name="update" value="Update Ranking" title="Save your rank." class="save_sortable_collage" />
|
<input type="submit" name="update" value="Update Ranking" title="Save your rank." class="save_sortable_collage" />
|
||||||
@ -279,8 +272,7 @@ public function buttons ()
|
|||||||
/**
|
/**
|
||||||
* @param string $EditType
|
* @param string $EditType
|
||||||
*/
|
*/
|
||||||
public function set_edit_type ($EditType)
|
public function set_edit_type ($EditType) {
|
||||||
{
|
|
||||||
$this->EditType = $EditType;
|
$this->EditType = $EditType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -288,8 +280,7 @@ public function set_edit_type ($EditType)
|
|||||||
* Set's the current page's heading
|
* Set's the current page's heading
|
||||||
* @param string $Heading
|
* @param string $Heading
|
||||||
*/
|
*/
|
||||||
public function set_heading ($Heading)
|
public function set_heading ($Heading) {
|
||||||
{
|
|
||||||
$this->Heading = $Heading;
|
$this->Heading = $Heading;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -126,8 +126,8 @@ function db_string($String,$DisableWildcards=false) {
|
|||||||
|
|
||||||
function db_array($Array, $DontEscape = array(), $Quote = false) {
|
function db_array($Array, $DontEscape = array(), $Quote = false) {
|
||||||
foreach ($Array as $Key => $Val) {
|
foreach ($Array as $Key => $Val) {
|
||||||
if(!in_array($Key, $DontEscape)) {
|
if (!in_array($Key, $DontEscape)) {
|
||||||
if($Quote) {
|
if ($Quote) {
|
||||||
$Array[$Key] = '\''.db_string(trim($Val)).'\'';
|
$Array[$Key] = '\''.db_string(trim($Val)).'\'';
|
||||||
} else {
|
} else {
|
||||||
$Array[$Key] = db_string(trim($Val));
|
$Array[$Key] = db_string(trim($Val));
|
||||||
@ -175,7 +175,7 @@ function halt($Msg) {
|
|||||||
$Debug->analysis('!dev DB Error',$DBError,3600*24);
|
$Debug->analysis('!dev DB Error',$DBError,3600*24);
|
||||||
if (DEBUG_MODE || check_perms('site_debug') || isset($argv[1])) {
|
if (DEBUG_MODE || check_perms('site_debug') || isset($argv[1])) {
|
||||||
echo '<pre>'.display_str($DBError).'</pre>';
|
echo '<pre>'.display_str($DBError).'</pre>';
|
||||||
if(DEBUG_MODE || check_perms('site_debug')) {
|
if (DEBUG_MODE || check_perms('site_debug')) {
|
||||||
print_r($this->Queries);
|
print_r($this->Queries);
|
||||||
}
|
}
|
||||||
die();
|
die();
|
||||||
@ -185,7 +185,7 @@ function halt($Msg) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function connect() {
|
function connect() {
|
||||||
if(!$this->LinkID) {
|
if (!$this->LinkID) {
|
||||||
$this->LinkID = mysqli_connect($this->Server, $this->User, $this->Pass, $this->Database, $this->Port, $this->Socket); // defined in config.php
|
$this->LinkID = mysqli_connect($this->Server, $this->User, $this->Pass, $this->Database, $this->Port, $this->Socket); // defined in config.php
|
||||||
if (!$this->LinkID) {
|
if (!$this->LinkID) {
|
||||||
$this->Errno = mysqli_connect_errno();
|
$this->Errno = mysqli_connect_errno();
|
||||||
@ -200,9 +200,9 @@ function query($Query,$AutoHandle=1) {
|
|||||||
$QueryStartTime=microtime(true);
|
$QueryStartTime=microtime(true);
|
||||||
$this->connect();
|
$this->connect();
|
||||||
//In the event of a mysql deadlock, we sleep allowing mysql time to unlock then attempt again for a maximum of 5 tries
|
//In the event of a mysql deadlock, we sleep allowing mysql time to unlock then attempt again for a maximum of 5 tries
|
||||||
for($i=1; $i<6; $i++) {
|
for($i = 1; $i < 6; $i++) {
|
||||||
$this->QueryID = mysqli_query($this->LinkID,$Query);
|
$this->QueryID = mysqli_query($this->LinkID,$Query);
|
||||||
if(!in_array(mysqli_errno($this->LinkID), array(1213, 1205))) {
|
if (!in_array(mysqli_errno($this->LinkID), array(1213, 1205))) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
$Debug->analysis('Non-Fatal Deadlock:',$Query,3600*24);
|
$Debug->analysis('Non-Fatal Deadlock:',$Query,3600*24);
|
||||||
@ -243,18 +243,18 @@ function query_unb($Query) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function inserted_id() {
|
function inserted_id() {
|
||||||
if($this->LinkID) {
|
if ($this->LinkID) {
|
||||||
return mysqli_insert_id($this->LinkID);
|
return mysqli_insert_id($this->LinkID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function next_record($Type=MYSQLI_BOTH, $Escape = true) { // $Escape can be true, false, or an array of keys to not escape
|
function next_record($Type=MYSQLI_BOTH, $Escape = true) { // $Escape can be true, false, or an array of keys to not escape
|
||||||
if($this->LinkID) {
|
if ($this->LinkID) {
|
||||||
$this->Record = mysqli_fetch_array($this->QueryID,$Type);
|
$this->Record = mysqli_fetch_array($this->QueryID,$Type);
|
||||||
$this->Row++;
|
$this->Row++;
|
||||||
if (!is_array($this->Record)) {
|
if (!is_array($this->Record)) {
|
||||||
$this->QueryID = FALSE;
|
$this->QueryID = false;
|
||||||
} elseif($Escape !== FALSE){
|
} elseif ($Escape !== false) {
|
||||||
$this->Record = Misc::display_array($this->Record, $Escape);
|
$this->Record = Misc::display_array($this->Record, $Escape);
|
||||||
}
|
}
|
||||||
return $this->Record;
|
return $this->Record;
|
||||||
@ -262,11 +262,11 @@ function next_record($Type=MYSQLI_BOTH, $Escape = true) { // $Escape can be true
|
|||||||
}
|
}
|
||||||
|
|
||||||
function close() {
|
function close() {
|
||||||
if($this->LinkID) {
|
if ($this->LinkID) {
|
||||||
if(!mysqli_close($this->LinkID)) {
|
if (!mysqli_close($this->LinkID)) {
|
||||||
$this->halt('Cannot close connection or connection did not open.');
|
$this->halt('Cannot close connection or connection did not open.');
|
||||||
}
|
}
|
||||||
$this->LinkID = FALSE;
|
$this->LinkID = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,7 +277,7 @@ function record_count() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function affected_rows() {
|
function affected_rows() {
|
||||||
if($this->LinkID) {
|
if ($this->LinkID) {
|
||||||
return mysqli_affected_rows($this->LinkID);
|
return mysqli_affected_rows($this->LinkID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -301,11 +301,11 @@ function escape_str($Str) {
|
|||||||
// Otherwise, use an integer
|
// Otherwise, use an integer
|
||||||
function to_array($Key = false, $Type = MYSQLI_BOTH, $Escape = true) {
|
function to_array($Key = false, $Type = MYSQLI_BOTH, $Escape = true) {
|
||||||
$Return = array();
|
$Return = array();
|
||||||
while($Row = mysqli_fetch_array($this->QueryID,$Type)){
|
while ($Row = mysqli_fetch_array($this->QueryID,$Type)) {
|
||||||
if($Escape!==FALSE) {
|
if ($Escape !== false) {
|
||||||
$Row = Misc::display_array($Row, $Escape);
|
$Row = Misc::display_array($Row, $Escape);
|
||||||
}
|
}
|
||||||
if($Key !== false) {
|
if ($Key !== false) {
|
||||||
$Return[$Row[$Key]] = $Row;
|
$Return[$Row[$Key]] = $Row;
|
||||||
} else {
|
} else {
|
||||||
$Return[]=$Row;
|
$Return[]=$Row;
|
||||||
|
@ -472,14 +472,14 @@ public static function regenerate_filelist($TorrentID) {
|
|||||||
JOIN torrents AS t ON t.ID=tf.TorrentID
|
JOIN torrents AS t ON t.ID=tf.TorrentID
|
||||||
JOIN torrents_group AS tg ON tg.ID=t.GroupID
|
JOIN torrents_group AS tg ON tg.ID=t.GroupID
|
||||||
WHERE tf.TorrentID = ".$TorrentID);
|
WHERE tf.TorrentID = ".$TorrentID);
|
||||||
if($DB->record_count() > 0) {
|
if ($DB->record_count() > 0) {
|
||||||
list($GroupID, $Contents) = $DB->next_record(MYSQLI_NUM, false);
|
list($GroupID, $Contents) = $DB->next_record(MYSQLI_NUM, false);
|
||||||
if (Misc::is_new_torrent($Contents)) {
|
if (Misc::is_new_torrent($Contents)) {
|
||||||
$Tor = new BencodeTorrent($Contents);
|
$Tor = new BencodeTorrent($Contents);
|
||||||
$FilePath = isset($Tor->Dec['info']['files']) ? Format::make_utf8($Tor->get_name()) : "";
|
$FilePath = isset($Tor->Dec['info']['files']) ? Format::make_utf8($Tor->get_name()) : '';
|
||||||
} else {
|
} else {
|
||||||
$Tor = new TORRENT(unserialize(base64_decode($Contents)), true);
|
$Tor = new TORRENT(unserialize(base64_decode($Contents)), true);
|
||||||
$FilePath = isset($Tor->Val['info']->Val['files']) ? Format::make_utf8($Tor->get_name()) : "";
|
$FilePath = isset($Tor->Val['info']->Val['files']) ? Format::make_utf8($Tor->get_name()) : '';
|
||||||
}
|
}
|
||||||
list($TotalSize, $FileList) = $Tor->file_list();
|
list($TotalSize, $FileList) = $Tor->file_list();
|
||||||
foreach($FileList as $File) {
|
foreach($FileList as $File) {
|
||||||
@ -753,17 +753,32 @@ public static function has_snatched($TorrentID, $AllUsers = false) {
|
|||||||
public static function edition_string(array $Torrent, array $Group) {
|
public static function edition_string(array $Torrent, array $Group) {
|
||||||
if ($Torrent['Remastered'] && $Torrent['RemasterYear'] != 0) {
|
if ($Torrent['Remastered'] && $Torrent['RemasterYear'] != 0) {
|
||||||
$EditionName = $Torrent['RemasterYear'];
|
$EditionName = $Torrent['RemasterYear'];
|
||||||
$AddExtra = " - ";
|
$AddExtra = ' - ';
|
||||||
if ($Torrent['RemasterRecordLabel']) { $EditionName .= $AddExtra . display_str($Torrent['RemasterRecordLabel']); $AddExtra = ' / '; }
|
if ($Torrent['RemasterRecordLabel']) {
|
||||||
if ($Torrent['RemasterCatalogueNumber']) { $EditionName .= $AddExtra . display_str($Torrent['RemasterCatalogueNumber']); $AddExtra = ' / '; }
|
$EditionName .= $AddExtra . display_str($Torrent['RemasterRecordLabel']);
|
||||||
if ($Torrent['RemasterTitle']) { $EditionName .= $AddExtra . display_str($Torrent['RemasterTitle']); $AddExtra = ' / '; }
|
$AddExtra = ' / ';
|
||||||
|
}
|
||||||
|
if ($Torrent['RemasterCatalogueNumber']) {
|
||||||
|
$EditionName .= $AddExtra . display_str($Torrent['RemasterCatalogueNumber']);
|
||||||
|
$AddExtra = ' / ';
|
||||||
|
}
|
||||||
|
if ($Torrent['RemasterTitle']) {
|
||||||
|
$EditionName .= $AddExtra . display_str($Torrent['RemasterTitle']);
|
||||||
|
$AddExtra = ' / ';
|
||||||
|
}
|
||||||
$EditionName .= $AddExtra . display_str($Torrent['Media']);
|
$EditionName .= $AddExtra . display_str($Torrent['Media']);
|
||||||
} else {
|
} else {
|
||||||
$AddExtra = " / ";
|
$AddExtra = " / ";
|
||||||
if(!$Torrent['Remastered']) {
|
if (!$Torrent['Remastered']) {
|
||||||
$EditionName = "Original Release";
|
$EditionName = "Original Release";
|
||||||
if ($Group['RecordLabel']) { $EditionName .= $AddExtra . $Group['RecordLabel']; $AddExtra = ' / '; }
|
if ($Group['RecordLabel']) {
|
||||||
if ($Group['CatalogueNumber']) { $EditionName .= $AddExtra . $Group['CatalogueNumber']; $AddExtra = ' / '; }
|
$EditionName .= $AddExtra . $Group['RecordLabel'];
|
||||||
|
$AddExtra = ' / ';
|
||||||
|
}
|
||||||
|
if ($Group['CatalogueNumber']) {
|
||||||
|
$EditionName .= $AddExtra . $Group['CatalogueNumber'];
|
||||||
|
$AddExtra = ' / ';
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
$EditionName = "Unknown Release(s)";
|
$EditionName = "Unknown Release(s)";
|
||||||
}
|
}
|
||||||
|
@ -143,7 +143,7 @@ public function browser(&$UserAgentString) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if($this->mobile($UserAgentString)) {
|
if ($this->mobile($UserAgentString)) {
|
||||||
$Return .= ' Mobile';
|
$Return .= ' Mobile';
|
||||||
}
|
}
|
||||||
return $Return;
|
return $Return;
|
||||||
|
@ -9,92 +9,163 @@ class VALIDATE {
|
|||||||
var $Fields=array();
|
var $Fields=array();
|
||||||
|
|
||||||
function SetFields($FieldName,$Required,$FieldType,$ErrorMessage,$Options=array()) {
|
function SetFields($FieldName,$Required,$FieldType,$ErrorMessage,$Options=array()) {
|
||||||
$this->Fields[$FieldName]['Type']=strtolower($FieldType);
|
$this->Fields[$FieldName]['Type'] = strtolower($FieldType);
|
||||||
$this->Fields[$FieldName]['Required']=$Required;
|
$this->Fields[$FieldName]['Required'] = $Required;
|
||||||
$this->Fields[$FieldName]['ErrorMessage']=$ErrorMessage;
|
$this->Fields[$FieldName]['ErrorMessage'] = $ErrorMessage;
|
||||||
if(!empty($Options['maxlength'])) {
|
if (!empty($Options['maxlength'])) {
|
||||||
$this->Fields[$FieldName]['MaxLength']=$Options['maxlength'];
|
$this->Fields[$FieldName]['MaxLength'] = $Options['maxlength'];
|
||||||
}
|
}
|
||||||
if(!empty($Options['minlength'])) {
|
if (!empty($Options['minlength'])) {
|
||||||
$this->Fields[$FieldName]['MinLength']=$Options['minlength'];
|
$this->Fields[$FieldName]['MinLength'] = $Options['minlength'];
|
||||||
}
|
}
|
||||||
if(!empty($Options['comparefield'])) {
|
if (!empty($Options['comparefield'])) {
|
||||||
$this->Fields[$FieldName]['CompareField']=$Options['comparefield'];
|
$this->Fields[$FieldName]['CompareField'] = $Options['comparefield'];
|
||||||
}
|
}
|
||||||
if(!empty($Options['allowperiod'])) {
|
if (!empty($Options['allowperiod'])) {
|
||||||
$this->Fields[$FieldName]['AllowPeriod']=$Options['allowperiod'];
|
$this->Fields[$FieldName]['AllowPeriod'] = $Options['allowperiod'];
|
||||||
}
|
}
|
||||||
if(!empty($Options['allowcomma'])) {
|
if (!empty($Options['allowcomma'])) {
|
||||||
$this->Fields[$FieldName]['AllowComma']=$Options['allowcomma'];
|
$this->Fields[$FieldName]['AllowComma'] = $Options['allowcomma'];
|
||||||
}
|
}
|
||||||
if(!empty($Options['inarray'])) {
|
if (!empty($Options['inarray'])) {
|
||||||
$this->Fields[$FieldName]['InArray']=$Options['inarray'];
|
$this->Fields[$FieldName]['InArray'] = $Options['inarray'];
|
||||||
}
|
}
|
||||||
if(!empty($Options['regex'])) {
|
if (!empty($Options['regex'])) {
|
||||||
$this->Fields[$FieldName]['Regex']=$Options['regex'];
|
$this->Fields[$FieldName]['Regex'] = $Options['regex'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function ValidateForm($ValidateArray) {
|
function ValidateForm($ValidateArray) {
|
||||||
reset($this->Fields);
|
reset($this->Fields);
|
||||||
foreach ($this->Fields as $FieldKey => $Field) {
|
foreach ($this->Fields as $FieldKey => $Field) {
|
||||||
$ValidateVar=$ValidateArray[$FieldKey];
|
$ValidateVar = $ValidateArray[$FieldKey];
|
||||||
|
|
||||||
if($ValidateVar!="" || !empty($Field['Required']) || $Field['Type']=="date") {
|
if ($ValidateVar != '' || !empty($Field['Required']) || $Field['Type'] == 'date') {
|
||||||
if($Field['Type']=="string") {
|
if ($Field['Type'] == 'string') {
|
||||||
if(isset($Field['MaxLength'])) { $MaxLength=$Field['MaxLength']; } else { $MaxLength=255; }
|
if (isset($Field['MaxLength'])) {
|
||||||
if(isset($Field['MinLength'])) { $MinLength=$Field['MinLength']; } else { $MinLength=1; }
|
$MaxLength = $Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$MaxLength = 255;
|
||||||
|
}
|
||||||
|
if (isset($Field['MinLength'])) {
|
||||||
|
$MinLength = $Field['MinLength'];
|
||||||
|
} else {
|
||||||
|
$MinLength = 1;
|
||||||
|
}
|
||||||
|
|
||||||
if(strlen($ValidateVar)>$MaxLength) { return $Field['ErrorMessage']; }
|
if (strlen($ValidateVar) > $MaxLength) {
|
||||||
elseif(strlen($ValidateVar)<$MinLength) { return $Field['ErrorMessage']; }
|
return $Field['ErrorMessage'];
|
||||||
|
} elseif (strlen($ValidateVar) < $MinLength) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="number") {
|
} elseif ($Field['Type'] == 'number') {
|
||||||
if(isset($Field['MaxLength'])) { $MaxLength=$Field['MaxLength']; } else { $MaxLength=''; }
|
if (isset($Field['MaxLength'])) {
|
||||||
if(isset($Field['MinLength'])) { $MinLength=$Field['MinLength']; } else { $MinLength=0; }
|
$MaxLength = $Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$MaxLength = '';
|
||||||
|
}
|
||||||
|
if (isset($Field['MinLength'])) {
|
||||||
|
$MinLength = $Field['MinLength'];
|
||||||
|
} else {
|
||||||
|
$MinLength = 0;
|
||||||
|
}
|
||||||
|
|
||||||
$Match='0-9';
|
$Match = '0-9';
|
||||||
if(isset($Field['AllowPeriod'])) { $Match.='.'; }
|
if (isset($Field['AllowPeriod'])) {
|
||||||
if(isset($Field['AllowComma'])) { $Match.=','; }
|
$Match.='.';
|
||||||
|
}
|
||||||
|
if (isset($Field['AllowComma'])) {
|
||||||
|
$Match.=',';
|
||||||
|
}
|
||||||
|
|
||||||
if(preg_match('/[^'.$Match.']/', $ValidateVar) || strlen($ValidateVar)<1) { return $Field['ErrorMessage']; }
|
if (preg_match('/[^'.$Match.']/', $ValidateVar) || strlen($ValidateVar) < 1) {
|
||||||
elseif($MaxLength!="" && $ValidateVar>$MaxLength) { return $Field['ErrorMessage']."!!"; }
|
return $Field['ErrorMessage'];
|
||||||
elseif($ValidateVar<$MinLength) { return $Field['ErrorMessage']."$MinLength"; }
|
} elseif ($MaxLength != '' && $ValidateVar > $MaxLength) {
|
||||||
|
return $Field['ErrorMessage'].'!!';
|
||||||
|
} elseif ($ValidateVar < $MinLength) {
|
||||||
|
return $Field['ErrorMessage']."$MinLength";
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="email") {
|
} elseif ($Field['Type'] == 'email') {
|
||||||
if(isset($Field['MaxLength'])) { $MaxLength=$Field['MaxLength']; } else { $MaxLength=255; }
|
if (isset($Field['MaxLength'])) {
|
||||||
if(isset($Field['MinLength'])) { $MinLength=$Field['MinLength']; } else { $MinLength=6; }
|
$MaxLength = $Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$MaxLength = 255;
|
||||||
|
}
|
||||||
|
if (isset($Field['MinLength'])) {
|
||||||
|
$MinLength = $Field['MinLength'];
|
||||||
|
} else {
|
||||||
|
$MinLength = 6;
|
||||||
|
}
|
||||||
|
|
||||||
if(!preg_match("/^".EMAIL_REGEX."$/i", $ValidateVar)) { return $Field['ErrorMessage']; }
|
if (!preg_match("/^".EMAIL_REGEX."$/i", $ValidateVar)) {
|
||||||
elseif(strlen($ValidateVar)>$MaxLength) { return $Field['ErrorMessage']; }
|
return $Field['ErrorMessage'];
|
||||||
elseif(strlen($ValidateVar)<$MinLength) { return $Field['ErrorMessage']; }
|
} elseif (strlen($ValidateVar) > $MaxLength) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
} elseif (strlen($ValidateVar) < $MinLength) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="link") {
|
} elseif ($Field['Type'] == 'link') {
|
||||||
if(isset($Field['MaxLength'])) { $MaxLength=$Field['MaxLength']; } else { $MaxLength=255; }
|
if (isset($Field['MaxLength'])) {
|
||||||
if(isset($Field['MinLength'])) { $MinLength=$Field['MinLength']; } else { $MinLength=10; }
|
$MaxLength = $Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$MaxLength = 255;
|
||||||
|
}
|
||||||
|
if (isset($Field['MinLength'])) {
|
||||||
|
$MinLength = $Field['MinLength'];
|
||||||
|
} else {
|
||||||
|
$MinLength = 10;
|
||||||
|
}
|
||||||
|
|
||||||
if(!preg_match('/^(https?):\/\/([a-z0-9\-\_]+\.)+([a-z]{1,5}[^\.])(\/[^<>]+)*$/i', $ValidateVar)) { return $Field['ErrorMessage']; }
|
if (!preg_match('/^(https?):\/\/([a-z0-9\-\_]+\.)+([a-z]{1,5}[^\.])(\/[^<>]+)*$/i', $ValidateVar)) {
|
||||||
elseif(strlen($ValidateVar)>$MaxLength) { return $Field['ErrorMessage']; }
|
return $Field['ErrorMessage'];
|
||||||
elseif(strlen($ValidateVar)<$MinLength) { return $Field['ErrorMessage']; }
|
} elseif (strlen($ValidateVar) > $MaxLength) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
} elseif (strlen($ValidateVar) < $MinLength) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="username") {
|
} elseif ($Field['Type'] == 'username') {
|
||||||
if(isset($Field['MaxLength'])) { $MaxLength=$Field['MaxLength']; } else { $MaxLength=20; }
|
if (isset($Field['MaxLength'])) {
|
||||||
if(isset($Field['MinLength'])) { $MinLength=$Field['MinLength']; } else { $MinLength=1; }
|
$MaxLength = $Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$MaxLength = 20;
|
||||||
|
}
|
||||||
|
if (isset($Field['MinLength'])) {
|
||||||
|
$MinLength = $Field['MinLength'];
|
||||||
|
} else {
|
||||||
|
$MinLength = 1;
|
||||||
|
}
|
||||||
|
|
||||||
if(preg_match('/[^a-z0-9_\-?]/i', $ValidateVar)) { return $Field['ErrorMessage']; }
|
if (preg_match('/[^a-z0-9_\-?]/i', $ValidateVar)) {
|
||||||
elseif(strlen($ValidateVar)>$MaxLength) { return $Field['ErrorMessage']; }
|
return $Field['ErrorMessage'];
|
||||||
elseif(strlen($ValidateVar)<$MinLength) { return $Field['ErrorMessage']; }
|
} elseif (strlen($ValidateVar) > $MaxLength) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
} elseif (strlen($ValidateVar) < $MinLength) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="checkbox") {
|
} elseif ($Field['Type'] == 'checkbox') {
|
||||||
if(!isset($ValidateArray[$FieldKey])) { return $Field['ErrorMessage']; }
|
if (!isset($ValidateArray[$FieldKey])) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="compare") {
|
} elseif ($Field['Type'] == 'compare') {
|
||||||
if($ValidateArray[$Field['CompareField']]!=$ValidateVar) { return $Field['ErrorMessage']; }
|
if ($ValidateArray[$Field['CompareField']]!=$ValidateVar) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="inarray") {
|
} elseif ($Field['Type'] == 'inarray') {
|
||||||
if(array_search($ValidateVar, $Field['InArray'])===false) { return $Field['ErrorMessage']; }
|
if (array_search($ValidateVar, $Field['InArray']) === false) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="regex") {
|
} elseif ($Field['Type'] == 'regex') {
|
||||||
if(!preg_match($Field['Regex'], $ValidateVar)) { return $Field['ErrorMessage']; }
|
if (!preg_match($Field['Regex'], $ValidateVar)) {
|
||||||
|
return $Field['ErrorMessage'];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // while
|
} // while
|
||||||
@ -108,52 +179,90 @@ function GenerateJS($FormID) {
|
|||||||
|
|
||||||
reset($this->Fields);
|
reset($this->Fields);
|
||||||
foreach ($this->Fields as $FieldKey => $Field) {
|
foreach ($this->Fields as $FieldKey => $Field) {
|
||||||
if($Field['Type']=="string") {
|
if ($Field['Type'] == 'string') {
|
||||||
$ValItem=' if($(\'#'.$FieldKey.'\').raw().value==""';
|
$ValItem=' if ($(\'#'.$FieldKey.'\').raw().value==""';
|
||||||
if(!empty($Field['MaxLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength']; } else { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>255'; }
|
if (!empty($Field['MaxLength'])) {
|
||||||
if(!empty($Field['MinLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength']; }
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>255';
|
||||||
|
}
|
||||||
|
if (!empty($Field['MinLength'])) {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength'];
|
||||||
|
}
|
||||||
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
} elseif($Field['Type']=="number") {
|
} elseif ($Field['Type'] == 'number') {
|
||||||
$Match='0-9';
|
$Match='0-9';
|
||||||
if(!empty($Field['AllowPeriod'])) { $Match.='.'; }
|
if (!empty($Field['AllowPeriod'])) {
|
||||||
if(!empty($Field['AllowComma'])) { $Match.=','; }
|
$Match.='.';
|
||||||
|
}
|
||||||
|
if (!empty($Field['AllowComma'])) {
|
||||||
|
$Match.=',';
|
||||||
|
}
|
||||||
|
|
||||||
$ValItem=' if($(\'#'.$FieldKey.'\').raw().value.match(/[^'.$Match.']/) || $(\'#'.$FieldKey.'\').raw().value.length<1';
|
$ValItem=' if ($(\'#'.$FieldKey.'\').raw().value.match(/[^'.$Match.']/) || $(\'#'.$FieldKey.'\').raw().value.length<1';
|
||||||
if(!empty($Field['MaxLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value/1>'.$Field['MaxLength']; }
|
if (!empty($Field['MaxLength'])) {
|
||||||
if(!empty($Field['MinLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value/1<'.$Field['MinLength']; }
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value/1>'.$Field['MaxLength'];
|
||||||
|
}
|
||||||
|
if (!empty($Field['MinLength'])) {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value/1<'.$Field['MinLength'];
|
||||||
|
}
|
||||||
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
} elseif($Field['Type']=="email") {
|
} elseif ($Field['Type'] == 'email') {
|
||||||
$ValItem=' if(!validEmail($(\'#'.$FieldKey.'\').raw().value)';
|
$ValItem=' if (!validEmail($(\'#'.$FieldKey.'\').raw().value)';
|
||||||
if(!empty($Field['MaxLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength']; } else { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>255'; }
|
if (!empty($Field['MaxLength'])) {
|
||||||
if(!empty($Field['MinLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength']; } else { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<6'; }
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>255';
|
||||||
|
}
|
||||||
|
if (!empty($Field['MinLength'])) {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength'];
|
||||||
|
} else {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<6';
|
||||||
|
}
|
||||||
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
} elseif($Field['Type']=="link") {
|
} elseif ($Field['Type'] == 'link') {
|
||||||
$ValItem=' if(!validLink($(\'#'.$FieldKey.'\').raw().value)';
|
$ValItem=' if (!validLink($(\'#'.$FieldKey.'\').raw().value)';
|
||||||
if(!empty($Field['MaxLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength']; } else { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>255'; }
|
if (!empty($Field['MaxLength'])) {
|
||||||
if(!empty($Field['MinLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength']; } else { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<10'; }
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength'];
|
||||||
|
} else {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>255';
|
||||||
|
}
|
||||||
|
if (!empty($Field['MinLength'])) {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength'];
|
||||||
|
} else {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<10';
|
||||||
|
}
|
||||||
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
} elseif($Field['Type']=="username") {
|
} elseif ($Field['Type'] == 'username') {
|
||||||
$ValItem=' if($(\'#'.$FieldKey.'\').raw().value.match(/[^a-zA-Z0-9_\-]/)';
|
$ValItem = ' if ($(\'#'.$FieldKey.'\').raw().value.match(/[^a-zA-Z0-9_\-]/)';
|
||||||
if(!empty($Field['MaxLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength']; }
|
if (!empty($Field['MaxLength'])) {
|
||||||
if(!empty($Field['MinLength'])) { $ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength']; }
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length>'.$Field['MaxLength'];
|
||||||
|
}
|
||||||
|
if (!empty($Field['MinLength'])) {
|
||||||
|
$ValItem.=' || $(\'#'.$FieldKey.'\').raw().value.length<'.$Field['MinLength'];
|
||||||
|
}
|
||||||
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem.=') { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
} elseif($Field['Type']=="regex") {
|
} elseif ($Field['Type'] == 'regex') {
|
||||||
$ValItem=' if(!$(\'#'.$FieldKey.'\').raw().value.match('.$Field['Regex'].')) { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem=' if (!$(\'#'.$FieldKey.'\').raw().value.match('.$Field['Regex'].')) { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
} elseif($Field['Type']=="date") {
|
} elseif ($Field['Type'] == 'date') {
|
||||||
$DisplayError=$FieldKey."month";
|
$DisplayError = $FieldKey.'month';
|
||||||
if(isset($Field['MinLength']) && $Field['MinLength']==3) { $Day='$(\'#'.$FieldKey.'day\').raw().value'; $DisplayError.=",".$FieldKey."day"; } else { $Day="1"; }
|
if (isset($Field['MinLength']) && $Field['MinLength'] == 3) {
|
||||||
|
$Day = '$(\'#'.$FieldKey.'day\').raw().value'; $DisplayError.=",".$FieldKey."day";
|
||||||
|
} else {
|
||||||
|
$Day = '1';
|
||||||
|
}
|
||||||
$DisplayError.=",".$FieldKey."year";
|
$DisplayError.=",".$FieldKey."year";
|
||||||
$ValItemHold=' if(!validDate($(\'#'.$FieldKey.'month\').raw().value+\'/\'+'.$Day.'+\'/\'+$(\'#'.$FieldKey.'year\').raw().value)) { return showError(\''.$DisplayError.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItemHold=' if (!validDate($(\'#'.$FieldKey.'month\').raw().value+\'/\'+'.$Day.'+\'/\'+$(\'#'.$FieldKey.'year\').raw().value)) { return showError(\''.$DisplayError.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
if(empty($Field['Required'])) {
|
if (empty($Field['Required'])) {
|
||||||
$ValItem=' if($(\'#'.$FieldKey.'month\').raw().value!=""';
|
$ValItem=' if ($(\'#'.$FieldKey.'month\').raw().value!=""';
|
||||||
if(isset($Field['MinLength']) && $Field['MinLength']==3) { $ValItem.=' || $(\'#'.$FieldKey.'day\').raw().value!=""'; }
|
if (isset($Field['MinLength']) && $Field['MinLength'] == 3) { $ValItem.=' || $(\'#'.$FieldKey.'day\').raw().value!=""'; }
|
||||||
$ValItem.=' || $(\'#'.$FieldKey.'year\').raw().value!="") {'."\r\n";
|
$ValItem.=' || $(\'#'.$FieldKey.'year\').raw().value!="") {'."\r\n";
|
||||||
$ValItem.=$ValItemHold;
|
$ValItem.=$ValItemHold;
|
||||||
$ValItem.=" }\r\n";
|
$ValItem.=" }\r\n";
|
||||||
@ -161,15 +270,15 @@ function GenerateJS($FormID) {
|
|||||||
$ValItem.=$ValItemHold;
|
$ValItem.=$ValItemHold;
|
||||||
}
|
}
|
||||||
|
|
||||||
} elseif($Field['Type']=="checkbox") {
|
} elseif ($Field['Type'] == 'checkbox') {
|
||||||
$ValItem=' if(!$(\'#'.$FieldKey.'\').checked) { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem=' if (!$(\'#'.$FieldKey.'\').checked) { return showError(\''.$FieldKey.'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
|
|
||||||
} elseif($Field['Type']=="compare") {
|
} elseif ($Field['Type'] == 'compare') {
|
||||||
$ValItem=' if($(\'#'.$FieldKey.'\').raw().value!=$(\'#'.$Field['CompareField'].'\').raw().value) { return showError(\''.$FieldKey.','.$Field['CompareField'].'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
$ValItem=' if ($(\'#'.$FieldKey.'\').raw().value!=$(\'#'.$Field['CompareField'].'\').raw().value) { return showError(\''.$FieldKey.','.$Field['CompareField'].'\',\''.$Field['ErrorMessage'].'\'); }'."\r\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
if(empty($Field['Required']) && $Field['Type']!="date") {
|
if (empty($Field['Required']) && $Field['Type'] != 'date') {
|
||||||
$ReturnJS.=' if($(\'#'.$FieldKey.'\').raw().value!="") {'."\r\n ";
|
$ReturnJS.=' if ($(\'#'.$FieldKey.'\').raw().value!="") {'."\r\n ";
|
||||||
$ReturnJS.=$ValItem;
|
$ReturnJS.=$ValItem;
|
||||||
$ReturnJS.=" }\r\n";
|
$ReturnJS.=" }\r\n";
|
||||||
} else {
|
} else {
|
||||||
|
@ -35,7 +35,7 @@ public static function get_user_votes($UserID) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$UserVotes = $Cache->get_value('voted_albums_'.$UserID);
|
$UserVotes = $Cache->get_value('voted_albums_'.$UserID);
|
||||||
if ($UserVotes === FALSE) {
|
if ($UserVotes === false) {
|
||||||
$DB->query('SELECT GroupID, Type FROM users_votes WHERE UserID='.$UserID);
|
$DB->query('SELECT GroupID, Type FROM users_votes WHERE UserID='.$UserID);
|
||||||
$UserVotes = $DB->to_array('GroupID', MYSQL_ASSOC, false);
|
$UserVotes = $DB->to_array('GroupID', MYSQL_ASSOC, false);
|
||||||
$Cache->cache_value('voted_albums_'.$UserID, $UserVotes);
|
$Cache->cache_value('voted_albums_'.$UserID, $UserVotes);
|
||||||
@ -54,7 +54,7 @@ public static function get_group_votes($GroupID) {
|
|||||||
global $DB, $Cache;
|
global $DB, $Cache;
|
||||||
|
|
||||||
$GroupVotes = $Cache->get_value('votes_'.$GroupID);
|
$GroupVotes = $Cache->get_value('votes_'.$GroupID);
|
||||||
if ($GroupVotes === FALSE) {
|
if ($GroupVotes === false) {
|
||||||
$DB->query("SELECT Ups AS Ups, Total AS Total FROM torrents_votes WHERE GroupID=$GroupID");
|
$DB->query("SELECT Ups AS Ups, Total AS Total FROM torrents_votes WHERE GroupID=$GroupID");
|
||||||
if ($DB->record_count() == 0) {
|
if ($DB->record_count() == 0) {
|
||||||
$GroupVotes = array('Ups'=>0, 'Total'=>0);
|
$GroupVotes = array('Ups'=>0, 'Total'=>0);
|
||||||
@ -204,7 +204,7 @@ public static function get_rank_all($GroupID) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$Rankings = $Cache->get_value('voting_ranks_overall');
|
$Rankings = $Cache->get_value('voting_ranks_overall');
|
||||||
if ($Rankings === FALSE) {
|
if ($Rankings === false) {
|
||||||
$Rankings = array();
|
$Rankings = array();
|
||||||
$i = 0;
|
$i = 0;
|
||||||
$DB->query("SELECT GroupID FROM torrents_votes ORDER BY Score DESC LIMIT 100");
|
$DB->query("SELECT GroupID FROM torrents_votes ORDER BY Score DESC LIMIT 100");
|
||||||
@ -235,7 +235,7 @@ public static function get_rank_year($GroupID, $Year) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$Rankings = $Cache->get_value('voting_ranks_year_'.$Year);
|
$Rankings = $Cache->get_value('voting_ranks_year_'.$Year);
|
||||||
if ($Rankings === FALSE) {
|
if ($Rankings === false) {
|
||||||
$Rankings = array();
|
$Rankings = array();
|
||||||
$i = 0;
|
$i = 0;
|
||||||
$DB->query("SELECT GroupID
|
$DB->query("SELECT GroupID
|
||||||
@ -274,7 +274,7 @@ public static function get_rank_decade($GroupID, $Year) {
|
|||||||
$Year = $Year - ($Year % 10);
|
$Year = $Year - ($Year % 10);
|
||||||
|
|
||||||
$Rankings = $Cache->get_value('voting_ranks_decade_'.$Year);
|
$Rankings = $Cache->get_value('voting_ranks_decade_'.$Year);
|
||||||
if ($Rankings === FALSE) {
|
if ($Rankings === false) {
|
||||||
$Rankings = array();
|
$Rankings = array();
|
||||||
$i = 0;
|
$i = 0;
|
||||||
$DB->query("SELECT GroupID
|
$DB->query("SELECT GroupID
|
||||||
|
@ -79,8 +79,10 @@
|
|||||||
/*
|
/*
|
||||||
//Handles timestamps
|
//Handles timestamps
|
||||||
function dostime($TimeStamp = 0) {
|
function dostime($TimeStamp = 0) {
|
||||||
if(!is_number($TimeStamp)) { // Assume that $TimeStamp is SQL timestamp
|
if (!is_number($TimeStamp)) { // Assume that $TimeStamp is SQL timestamp
|
||||||
if($TimeStamp == '0000-00-00 00:00:00') { return 'Never'; }
|
if ($TimeStamp == '0000-00-00 00:00:00') {
|
||||||
|
return 'Never';
|
||||||
|
}
|
||||||
$TimeStamp = strtotime($TimeStamp);
|
$TimeStamp = strtotime($TimeStamp);
|
||||||
}
|
}
|
||||||
$Date = ($TimeStamp == 0) ? getdate() : getdate($TimeStamp);
|
$Date = ($TimeStamp == 0) ? getdate() : getdate($TimeStamp);
|
||||||
|
@ -30,10 +30,10 @@ function is_number($Str) {
|
|||||||
* @return string escaped string.
|
* @return string escaped string.
|
||||||
*/
|
*/
|
||||||
function display_str($Str) {
|
function display_str($Str) {
|
||||||
if ($Str === NULL || $Str === FALSE || is_array($Str)) {
|
if ($Str === NULL || $Str === false || is_array($Str)) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
if ($Str!='' && !is_number($Str)) {
|
if ($Str != '' && !is_number($Str)) {
|
||||||
$Str = Format::make_utf8($Str);
|
$Str = Format::make_utf8($Str);
|
||||||
$Str = mb_convert_encoding($Str,"HTML-ENTITIES","UTF-8");
|
$Str = mb_convert_encoding($Str,"HTML-ENTITIES","UTF-8");
|
||||||
$Str = preg_replace("/&(?![A-Za-z]{0,4}\w{2,3};|#[0-9]{2,5};)/m","&",$Str);
|
$Str = preg_replace("/&(?![A-Za-z]{0,4}\w{2,3};|#[0-9]{2,5};)/m","&",$Str);
|
||||||
|
@ -20,11 +20,11 @@
|
|||||||
$Load = sys_getloadavg();
|
$Load = sys_getloadavg();
|
||||||
?>
|
?>
|
||||||
<p>Site and design © <?=date("Y")?> <?=SITE_NAME?></p>
|
<p>Site and design © <?=date("Y")?> <?=SITE_NAME?></p>
|
||||||
<? if(!empty($LastActive)) { ?>
|
<? if (!empty($LastActive)) { ?>
|
||||||
<p><a href="user.php?action=sessions" title="Manage sessions">Last activity <?=time_diff($LastActive['LastUpdate'])?> from <?=$LastActive['IP']?>.</a></p>
|
<p><a href="user.php?action=sessions" title="Manage sessions">Last activity <?=time_diff($LastActive['LastUpdate'])?> from <?=$LastActive['IP']?>.</a></p>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<p>
|
<p>
|
||||||
<strong>Time:</strong> <?=number_format(((microtime(true)-$ScriptStartTime)*1000),5)?> ms
|
<strong>Time:</strong> <?=number_format(((microtime(true) - $ScriptStartTime) * 1000),5)?> ms
|
||||||
<strong>Used:</strong> <?=Format::get_size(memory_get_usage(true))?>
|
<strong>Used:</strong> <?=Format::get_size(memory_get_usage(true))?>
|
||||||
<strong>Load:</strong> <?=number_format($Load[0],2).' '.number_format($Load[1],2).' '.number_format($Load[2],2)?>
|
<strong>Load:</strong> <?=number_format($Load[0],2).' '.number_format($Load[1],2).' '.number_format($Load[2],2)?>
|
||||||
<strong>Date:</strong> <?=date('M d Y, H:i')?>
|
<strong>Date:</strong> <?=date('M d Y, H:i')?>
|
||||||
|
@ -26,11 +26,21 @@
|
|||||||
global $LoggedUser, $HeavyInfo, $UserSubscriptions, $ThreadInfo,
|
global $LoggedUser, $HeavyInfo, $UserSubscriptions, $ThreadInfo,
|
||||||
$ForumsDoublePost;
|
$ForumsDoublePost;
|
||||||
|
|
||||||
if ($LoggedUser['DisablePosting']) return;
|
if ($LoggedUser['DisablePosting']) {
|
||||||
if (!isset($TextareaCols)) $TextareaCols = 70;
|
return;
|
||||||
if (!isset($TextareaRows)) $TextareaRows = 8;
|
}
|
||||||
if (!isset($InputAction)) $InputAction = 'reply';
|
if (!isset($TextareaCols)) {
|
||||||
if (!isset($InputTitle)) $InputTitle = 'Post comment';
|
$TextareaCols = 70;
|
||||||
|
}
|
||||||
|
if (!isset($TextareaRows)) {
|
||||||
|
$TextareaRows = 8;
|
||||||
|
}
|
||||||
|
if (!isset($InputAction)) {
|
||||||
|
$InputAction = 'reply';
|
||||||
|
}
|
||||||
|
if (!isset($InputTitle)) {
|
||||||
|
$InputTitle = 'Post comment';
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: Remove inline styles
|
// TODO: Remove inline styles
|
||||||
|
|
||||||
@ -52,18 +62,18 @@
|
|||||||
<div class="box pad">
|
<div class="box pad">
|
||||||
<table class="forum_post box vertical_margin hidden preview_wrap" id="preview_wrap_<?=$ReplyText->getID()?>">
|
<table class="forum_post box vertical_margin hidden preview_wrap" id="preview_wrap_<?=$ReplyText->getID()?>">
|
||||||
<colgroup>
|
<colgroup>
|
||||||
<? if(Users::has_avatars_enabled()) { ?>
|
<? if (Users::has_avatars_enabled()) { ?>
|
||||||
<col class="col_avatar" />
|
<col class="col_avatar" />
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<col class="col_post_body" />
|
<col class="col_post_body" />
|
||||||
</colgroup>
|
</colgroup>
|
||||||
<tr class="colhead_dark">
|
<tr class="colhead_dark">
|
||||||
<td colspan="<?=Users::has_avatars_enabled() ? 2 : 1?>">
|
<td colspan="<?=Users::has_avatars_enabled() ? 2 : 1?>">
|
||||||
<div style="float:left;"><a href='#quickreplypreview'>#XXXXXX</a>
|
<div style="float: left;"><a href='#quickreplypreview'>#XXXXXX</a>
|
||||||
by <strong><?=Users::format_username($LoggedUser['ID'], true, true, true, true)?></strong> Just now
|
by <strong><?=Users::format_username($LoggedUser['ID'], true, true, true, true)?></strong> Just now
|
||||||
</div>
|
</div>
|
||||||
<div style="float:right;">
|
<div style="float: right;">
|
||||||
[<a href="#quickreplypreview">Report</a>]
|
<a href="#quickreplypreview" class="brackets">Report</a>
|
||||||
|
|
||||||
<a href="#">↑</a>
|
<a href="#">↑</a>
|
||||||
</div>
|
</div>
|
||||||
@ -76,13 +86,13 @@
|
|||||||
</td>
|
</td>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<td class="body" valign="top">
|
<td class="body" valign="top">
|
||||||
<div id="contentpreview" style="text-align:left;">
|
<div id="contentpreview" style="text-align: left;">
|
||||||
<div id="preview_<?=$ReplyText->getID()?>"></div>
|
<div id="preview_<?=$ReplyText->getID()?>"></div>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<form class="send_form center" name="reply" id="quickpostform" action="" method="post"<? if(!check_perms('users_mod')) { ?> onsubmit="quickpostform.submit_button.disabled=true;" <? } ?>>
|
<form class="send_form center" name="reply" id="quickpostform" action="" method="post"<? if (!check_perms('users_mod')) { ?> onsubmit="quickpostform.submit_button.disabled=true;" <? } ?>>
|
||||||
<input type="hidden" name="action" value="<?=$InputAction?>" />
|
<input type="hidden" name="action" value="<?=$InputAction?>" />
|
||||||
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
||||||
<input type="hidden" name="<?=$InputName?>" value="<?=$InputID?>" />
|
<input type="hidden" name="<?=$InputName?>" value="<?=$InputID?>" />
|
||||||
@ -98,7 +108,7 @@
|
|||||||
// This might use some more abstraction
|
// This might use some more abstraction
|
||||||
if ($ForumID) { ?>
|
if ($ForumID) { ?>
|
||||||
<? if (!in_array($InputID, $UserSubscriptions)) { ?>
|
<? if (!in_array($InputID, $UserSubscriptions)) { ?>
|
||||||
<input id="subscribebox" type="checkbox" name="subscribe"<?=!empty($HeavyInfo['AutoSubscribe'])?' checked="checked"':''?> tabindex="2" />
|
<input id="subscribebox" type="checkbox" name="subscribe"<?=!empty($HeavyInfo['AutoSubscribe']) ? ' checked="checked"' : ''?> tabindex="2" />
|
||||||
<label for="subscribebox">Subscribe</label>
|
<label for="subscribebox">Subscribe</label>
|
||||||
<?
|
<?
|
||||||
}
|
}
|
||||||
@ -109,11 +119,12 @@
|
|||||||
?>
|
?>
|
||||||
<input id="mergebox" type="checkbox" name="merge" tabindex="2" />
|
<input id="mergebox" type="checkbox" name="merge" tabindex="2" />
|
||||||
<label for="mergebox">Merge</label>
|
<label for="mergebox">Merge</label>
|
||||||
<? } ?>
|
<? }
|
||||||
<? if (!$LoggedUser['DisableAutoSave']) { ?>
|
if (!$LoggedUser['DisableAutoSave']) { ?>
|
||||||
<script type="application/javascript">var storedTempTextarea = new StoreText('quickpost', 'quickpostform', <?=$InputID?>);</script>
|
<script type="application/javascript">var storedTempTextarea = new StoreText('quickpost', 'quickpostform', <?=$InputID?>);</script>
|
||||||
<? } ?>
|
<? }
|
||||||
<? } ?>
|
}
|
||||||
|
?>
|
||||||
<input type="button" value="Preview" class="hidden button_preview_<?=$ReplyText->getID()?>" title="Preview text" tabindex="1" />
|
<input type="button" value="Preview" class="hidden button_preview_<?=$ReplyText->getID()?>" title="Preview text" tabindex="1" />
|
||||||
<input type="submit" value="Post reply" id="submit_button" tabindex="1" />
|
<input type="submit" value="Post reply" id="submit_button" tabindex="1" />
|
||||||
</div>
|
</div>
|
||||||
|
99
image.php
99
image.php
@ -7,17 +7,19 @@
|
|||||||
/********************************************************/
|
/********************************************************/
|
||||||
error_reporting(E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR);
|
error_reporting(E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR);
|
||||||
|
|
||||||
if(isset($_SERVER['http_if_modified_since'])) {
|
if (isset($_SERVER['http_if_modified_since'])) {
|
||||||
header("Status: 304 Not Modified");
|
header("Status: 304 Not Modified");
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
header('Expires: '.date('D, d-M-Y H:i:s \U\T\C',time()+3600*24*120)); //120 days
|
header('Expires: '.date('D, d-M-Y H:i:s \U\T\C',time() + 3600 * 24 * 120)); //120 days
|
||||||
header('Last-Modified: '.date('D, d-M-Y H:i:s \U\T\C',time()));
|
header('Last-Modified: '.date('D, d-M-Y H:i:s \U\T\C',time()));
|
||||||
|
|
||||||
require('classes/config.php'); //The config contains all site wide configuration information as well as memcached rules
|
require('classes/config.php'); //The config contains all site wide configuration information as well as memcached rules
|
||||||
|
|
||||||
if (!extension_loaded('gd')) { error('nogd'); }
|
if (!extension_loaded('gd')) {
|
||||||
|
error('nogd');
|
||||||
|
}
|
||||||
|
|
||||||
require(SERVER_ROOT.'/classes/class_cache.php'); //Require the caching class
|
require(SERVER_ROOT.'/classes/class_cache.php'); //Require the caching class
|
||||||
require(SERVER_ROOT.'/classes/class_encrypt.php'); //Require the encryption class
|
require(SERVER_ROOT.'/classes/class_encrypt.php'); //Require the encryption class
|
||||||
@ -26,9 +28,11 @@
|
|||||||
$Cache = NEW CACHE($MemcachedServers); //Load the caching class
|
$Cache = NEW CACHE($MemcachedServers); //Load the caching class
|
||||||
$Enc = NEW CRYPT; //Load the encryption class
|
$Enc = NEW CRYPT; //Load the encryption class
|
||||||
|
|
||||||
if (isset($_COOKIE['session'])) { $LoginCookie=$Enc->decrypt($_COOKIE['session']); }
|
if (isset($_COOKIE['session'])) {
|
||||||
if(isset($LoginCookie)) {
|
$LoginCookie=$Enc->decrypt($_COOKIE['session']);
|
||||||
list($SessionID, $UserID)=explode("|~|",$Enc->decrypt($LoginCookie));
|
}
|
||||||
|
if (isset($LoginCookie)) {
|
||||||
|
list($SessionID, $UserID) = explode("|~|",$Enc->decrypt($LoginCookie));
|
||||||
$UserID = (int)$UserID;
|
$UserID = (int)$UserID;
|
||||||
$UserInfo = $Cache->get_value('user_info_'.$UserID);
|
$UserInfo = $Cache->get_value('user_info_'.$UserID);
|
||||||
$Permissions = $Cache->get_value('perm_'.$UserInfo['PermissionID']);
|
$Permissions = $Cache->get_value('perm_'.$UserInfo['PermissionID']);
|
||||||
@ -40,15 +44,17 @@ function check_perms($PermissionName) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function error($Type) {
|
function error($Type) {
|
||||||
header('Content-type: image/gif');
|
header('Content-type: image/gif');
|
||||||
die(file_get_contents(SERVER_ROOT.'/sections/image/'.$Type.'.gif'));
|
die(file_get_contents(SERVER_ROOT.'/sections/image/'.$Type.'.gif'));
|
||||||
}
|
}
|
||||||
|
|
||||||
function invisible($Image) {
|
function invisible($Image) {
|
||||||
$Count = imagecolorstotal($Image);
|
$Count = imagecolorstotal($Image);
|
||||||
if ($Count == 0) { return false; }
|
if ($Count == 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
$TotalAlpha = 0;
|
$TotalAlpha = 0;
|
||||||
for ($i=0; $i<$Count; ++$i) {
|
for ($i = 0; $i < $Count; ++$i) {
|
||||||
$Color = imagecolorsforindex($Image,$i);
|
$Color = imagecolorsforindex($Image,$i);
|
||||||
$TotalAlpha += $Color['alpha'];
|
$TotalAlpha += $Color['alpha'];
|
||||||
}
|
}
|
||||||
@ -58,7 +64,9 @@ function invisible($Image) {
|
|||||||
|
|
||||||
function is_number($Str) {
|
function is_number($Str) {
|
||||||
$Return = true;
|
$Return = true;
|
||||||
if ($Str < 0) { $Return = false; }
|
if ($Str < 0) {
|
||||||
|
$Return = false;
|
||||||
|
}
|
||||||
// We're converting input to a int, then string and comparing to original
|
// We're converting input to a int, then string and comparing to original
|
||||||
$Return = ($Str == strval(intval($Str)) ? true : false);
|
$Return = ($Str == strval(intval($Str)) ? true : false);
|
||||||
return $Return;
|
return $Return;
|
||||||
@ -69,19 +77,19 @@ function verysmall($Image) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function image_type($Data) {
|
function image_type($Data) {
|
||||||
if(!strncmp($Data,'GIF',3)) {
|
if (!strncmp($Data,'GIF',3)) {
|
||||||
return 'gif';
|
return 'gif';
|
||||||
}
|
}
|
||||||
if(!strncmp($Data,pack('H*','89504E47'),4)) {
|
if (!strncmp($Data,pack('H*','89504E47'),4)) {
|
||||||
return 'png';
|
return 'png';
|
||||||
}
|
}
|
||||||
if(!strncmp($Data,pack('H*','FFD8'),2)) {
|
if (!strncmp($Data,pack('H*','FFD8'),2)) {
|
||||||
return 'jpeg';
|
return 'jpeg';
|
||||||
}
|
}
|
||||||
if(!strncmp($Data,'BM',2)) {
|
if (!strncmp($Data,'BM',2)) {
|
||||||
return 'bmp';
|
return 'bmp';
|
||||||
}
|
}
|
||||||
if(!strncmp($Data,'II',2) || !strncmp($Data,'MM',2)) {
|
if (!strncmp($Data,'II',2) || !strncmp($Data,'MM',2)) {
|
||||||
return 'tiff';
|
return 'tiff';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -89,25 +97,25 @@ function image_type($Data) {
|
|||||||
function image_height($Type, $Data) {
|
function image_height($Type, $Data) {
|
||||||
$Length = strlen($Data);
|
$Length = strlen($Data);
|
||||||
global $URL, $_GET;
|
global $URL, $_GET;
|
||||||
switch($Type) {
|
switch ($Type) {
|
||||||
case 'jpeg':
|
case 'jpeg':
|
||||||
// See http://www.obrador.com/essentialjpeg/headerinfo.htm
|
// See http://www.obrador.com/essentialjpeg/headerinfo.htm
|
||||||
$i = 4;
|
$i = 4;
|
||||||
$Data = (substr($Data, $i));
|
$Data = (substr($Data, $i));
|
||||||
$Block = unpack('nLength', $Data);
|
$Block = unpack('nLength', $Data);
|
||||||
$Data = substr($Data, $Block['Length']);
|
$Data = substr($Data, $Block['Length']);
|
||||||
$i+=$Block['Length'];
|
$i += $Block['Length'];
|
||||||
$Str []= "Started 4, + ".$Block['Length'];
|
$Str []= "Started 4, + ".$Block['Length'];
|
||||||
while($Data!='') { // iterate through the blocks until we find the start of frame marker (FFC0)
|
while ($Data != '') { // iterate through the blocks until we find the start of frame marker (FFC0)
|
||||||
$Block = unpack('CBlock/CType/nLength', $Data); // Get info about the block
|
$Block = unpack('CBlock/CType/nLength', $Data); // Get info about the block
|
||||||
if($Block['Block'] != '255') { break; } // We should be at the start of a new block
|
if ($Block['Block'] != '255') { break; } // We should be at the start of a new block
|
||||||
if($Block['Type'] != '192') { // C0
|
if ($Block['Type'] != '192') { // C0
|
||||||
$Data = substr($Data, $Block['Length']+2); // Next block
|
$Data = substr($Data, $Block['Length'] + 2); // Next block
|
||||||
$Str []= "Started ".$i.", + ".($Block['Length']+2);
|
$Str []= "Started ".$i.", + ".($Block['Length'] + 2);
|
||||||
$i+=($Block['Length']+2);
|
$i += ($Block['Length'] + 2);
|
||||||
} else { // We're at the FFC0 block
|
} else { // We're at the FFC0 block
|
||||||
$Data = substr($Data, 5); // Skip FF C0 Length(2) precision(1)
|
$Data = substr($Data, 5); // Skip FF C0 Length(2) precision(1)
|
||||||
$i+=5;
|
$i += 5;
|
||||||
$Height = unpack('nHeight', $Data);
|
$Height = unpack('nHeight', $Data);
|
||||||
return $Height['Height'];
|
return $Height['Height'];
|
||||||
}
|
}
|
||||||
@ -129,12 +137,12 @@ function image_height($Type, $Data) {
|
|||||||
|
|
||||||
function send_pm($ToID,$FromID,$Subject,$Body,$ConvID='') {
|
function send_pm($ToID,$FromID,$Subject,$Body,$ConvID='') {
|
||||||
global $DB, $Cache;
|
global $DB, $Cache;
|
||||||
if($ToID==0) {
|
if ($ToID == 0) {
|
||||||
// Don't allow users to send messages to the system
|
// Don't allow users to send messages to the system
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if($ConvID=='') {
|
if ($ConvID == '') {
|
||||||
$DB->query("INSERT INTO pm_conversations(Subject) VALUES ('".$Subject."')");
|
$DB->query("INSERT INTO pm_conversations(Subject) VALUES ('$Subject')");
|
||||||
$ConvID = $DB->inserted_id();
|
$ConvID = $DB->inserted_id();
|
||||||
$DB->query("INSERT INTO pm_conversations_users
|
$DB->query("INSERT INTO pm_conversations_users
|
||||||
(UserID, ConvID, InInbox, InSentbox, SentDate, ReceivedDate, UnRead) VALUES
|
(UserID, ConvID, InInbox, InSentbox, SentDate, ReceivedDate, UnRead) VALUES
|
||||||
@ -181,36 +189,45 @@ function send_irc($Raw) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function display_str($Str) {
|
function display_str($Str) {
|
||||||
if ($Str === NULL || $Str === FALSE || is_array($Str)) {
|
if ($Str === NULL || $Str === false || is_array($Str)) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
if ($Str!='' && !is_number($Str)) {
|
if ($Str != '' && !is_number($Str)) {
|
||||||
$Str=make_utf8($Str);
|
$Str = make_utf8($Str);
|
||||||
$Str=mb_convert_encoding($Str,"HTML-ENTITIES","UTF-8");
|
$Str = mb_convert_encoding($Str,"HTML-ENTITIES","UTF-8");
|
||||||
$Str=preg_replace("/&(?![A-Za-z]{0,4}\w{2,3};|#[0-9]{2,5};)/m","&",$Str);
|
$Str = preg_replace("/&(?![A-Za-z]{0,4}\w{2,3};|#[0-9]{2,5};)/m","&",$Str);
|
||||||
|
|
||||||
$Replace = array(
|
$Replace = array(
|
||||||
"'",'"',"<",">",
|
"'",'"',"<",">",
|
||||||
'€','‚','ƒ','„','…','†','‡','ˆ','‰','Š','‹','Œ','Ž','‘','’','“','”','•','–','—','˜','™','š','›','œ','ž','Ÿ'
|
'€','‚','ƒ','„','…','†','‡','ˆ','‰','Š','‹','Œ','Ž','‘','’','“','”','•','–','—','˜','™','š','›','œ','ž','Ÿ'
|
||||||
);
|
);
|
||||||
|
|
||||||
$With=array(
|
$With = array(
|
||||||
''','"','<','>',
|
''','"','<','>',
|
||||||
'€','‚','ƒ','„','…','†','‡','ˆ','‰','Š','‹','Œ','Ž','‘','’','“','”','•','–','—','˜','™','š','›','œ','ž','Ÿ'
|
'€','‚','ƒ','„','…','†','‡','ˆ','‰','Š','‹','Œ','Ž','‘','’','“','”','•','–','—','˜','™','š','›','œ','ž','Ÿ'
|
||||||
);
|
);
|
||||||
|
|
||||||
$Str=str_replace($Replace,$With,$Str);
|
$Str = str_replace($Replace,$With,$Str);
|
||||||
}
|
}
|
||||||
return $Str;
|
return $Str;
|
||||||
}
|
}
|
||||||
|
|
||||||
function make_utf8($Str) {
|
function make_utf8($Str) {
|
||||||
if ($Str!="") {
|
if ($Str != '') {
|
||||||
if (is_utf8($Str)) { $Encoding="UTF-8"; }
|
if (is_utf8($Str)) {
|
||||||
if (empty($Encoding)) { $Encoding=mb_detect_encoding($Str,'UTF-8, ISO-8859-1'); }
|
$Encoding = 'UTF-8';
|
||||||
if (empty($Encoding)) { $Encoding="ISO-8859-1"; }
|
}
|
||||||
if ($Encoding=="UTF-8") { return $Str; }
|
if (empty($Encoding)) {
|
||||||
else { return @mb_convert_encoding($Str,"UTF-8",$Encoding); }
|
$Encoding = mb_detect_encoding($Str,'UTF-8, ISO-8859-1');
|
||||||
|
}
|
||||||
|
if (empty($Encoding)) {
|
||||||
|
$Encoding = 'ISO-8859-1';
|
||||||
|
}
|
||||||
|
if ($Encoding == 'UTF-8') {
|
||||||
|
return $Str;
|
||||||
|
} else {
|
||||||
|
return @mb_convert_encoding($Str,'UTF-8',$Encoding);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,14 +9,14 @@
|
|||||||
|
|
||||||
//We have to iterate here because if one is empty it breaks the query
|
//We have to iterate here because if one is empty it breaks the query
|
||||||
$TopicIDs = array();
|
$TopicIDs = array();
|
||||||
foreach($Forums as $Forum) {
|
foreach ($Forums as $Forum) {
|
||||||
if (!empty($Forum['LastPostTopicID'])) {
|
if (!empty($Forum['LastPostTopicID'])) {
|
||||||
$TopicIDs[]=$Forum['LastPostTopicID'];
|
$TopicIDs[] = $Forum['LastPostTopicID'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Now if we have IDs' we run the query
|
//Now if we have IDs' we run the query
|
||||||
if(!empty($TopicIDs)) {
|
if (!empty($TopicIDs)) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
l.TopicID,
|
l.TopicID,
|
||||||
l.PostID,
|
l.PostID,
|
||||||
@ -39,12 +39,12 @@
|
|||||||
$JsonForums = array();
|
$JsonForums = array();
|
||||||
foreach ($Forums as $Forum) {
|
foreach ($Forums as $Forum) {
|
||||||
list($ForumID, $CategoryID, $ForumName, $ForumDescription, $MinRead, $MinWrite, $MinCreate, $NumTopics, $NumPosts, $LastPostID, $LastAuthorID, $LastTopicID, $LastTime, $SpecificRules, $LastTopic, $Locked, $Sticky) = array_values($Forum);
|
list($ForumID, $CategoryID, $ForumName, $ForumDescription, $MinRead, $MinWrite, $MinCreate, $NumTopics, $NumPosts, $LastPostID, $LastAuthorID, $LastTopicID, $LastTime, $SpecificRules, $LastTopic, $Locked, $Sticky) = array_values($Forum);
|
||||||
if ($LoggedUser['CustomForums'][$ForumID] != 1 && ($MinRead>$LoggedUser['Class'] || array_search($ForumID, $RestrictedForums) !== FALSE)) {
|
if ($LoggedUser['CustomForums'][$ForumID] != 1 && ($MinRead>$LoggedUser['Class'] || array_search($ForumID, $RestrictedForums) !== false)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$ForumDescription = display_str($ForumDescription);
|
$ForumDescription = display_str($ForumDescription);
|
||||||
|
|
||||||
if($CategoryID!=$LastCategoryID) {
|
if ($CategoryID != $LastCategoryID) {
|
||||||
if (!empty($JsonForums) && !empty($JsonCategory)) {
|
if (!empty($JsonForums) && !empty($JsonCategory)) {
|
||||||
$JsonCategory['forums'] = $JsonForums;
|
$JsonCategory['forums'] = $JsonForums;
|
||||||
$JsonCategories[] = $JsonCategory;
|
$JsonCategories[] = $JsonCategory;
|
||||||
@ -57,7 +57,7 @@
|
|||||||
$JsonForums = array();
|
$JsonForums = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
if((!$Locked || $Sticky) && $LastPostID != 0 && ((empty($LastRead[$LastTopicID]) || $LastRead[$LastTopicID]['PostID'] < $LastPostID) && strtotime($LastTime)>$LoggedUser['CatchupTime'])) {
|
if ((!$Locked || $Sticky) && $LastPostID != 0 && ((empty($LastRead[$LastTopicID]) || $LastRead[$LastTopicID]['PostID'] < $LastPostID) && strtotime($LastTime) > $LoggedUser['CatchupTime'])) {
|
||||||
$Read = 'unread';
|
$Read = 'unread';
|
||||||
} else {
|
} else {
|
||||||
$Read = 'read';
|
$Read = 'read';
|
||||||
|
@ -17,14 +17,13 @@
|
|||||||
$Text = new TEXT;
|
$Text = new TEXT;
|
||||||
|
|
||||||
// Check for lame SQL injection attempts
|
// Check for lame SQL injection attempts
|
||||||
if(!isset($_GET['threadid']) || !is_number($_GET['threadid'])) {
|
if (!isset($_GET['threadid']) || !is_number($_GET['threadid'])) {
|
||||||
if(isset($_GET['topicid']) && is_number($_GET['topicid'])) {
|
if (isset($_GET['topicid']) && is_number($_GET['topicid'])) {
|
||||||
$ThreadID = $_GET['topicid'];
|
$ThreadID = $_GET['topicid'];
|
||||||
}
|
} elseif (isset($_GET['postid']) && is_number($_GET['postid'])) {
|
||||||
elseif(isset($_GET['postid']) && is_number($_GET['postid'])) {
|
|
||||||
$DB->query("SELECT TopicID FROM forums_posts WHERE ID = $_GET[postid]");
|
$DB->query("SELECT TopicID FROM forums_posts WHERE ID = $_GET[postid]");
|
||||||
list($ThreadID) = $DB->next_record();
|
list($ThreadID) = $DB->next_record();
|
||||||
if($ThreadID) {
|
if ($ThreadID) {
|
||||||
header("Location: ajax.php?action=forum&type=viewthread&threadid=$ThreadID&postid=$_GET[postid]");
|
header("Location: ajax.php?action=forum&type=viewthread&threadid=$ThreadID&postid=$_GET[postid]");
|
||||||
die();
|
die();
|
||||||
} else {
|
} else {
|
||||||
@ -41,8 +40,7 @@
|
|||||||
|
|
||||||
if (isset($_GET['pp'])) {
|
if (isset($_GET['pp'])) {
|
||||||
$PerPage = $_GET['pp'];
|
$PerPage = $_GET['pp'];
|
||||||
}
|
} elseif (isset($LoggedUser['PostsPerPage'])) {
|
||||||
else if (isset($LoggedUser['PostsPerPage'])) {
|
|
||||||
$PerPage = $LoggedUser['PostsPerPage'];
|
$PerPage = $LoggedUser['PostsPerPage'];
|
||||||
} else {
|
} else {
|
||||||
$PerPage = POSTS_PER_PAGE;
|
$PerPage = POSTS_PER_PAGE;
|
||||||
@ -55,16 +53,16 @@
|
|||||||
$ForumID = $ThreadInfo['ForumID'];
|
$ForumID = $ThreadInfo['ForumID'];
|
||||||
|
|
||||||
// Make sure they're allowed to look at the page
|
// Make sure they're allowed to look at the page
|
||||||
if(!check_forumperm($ForumID)) {
|
if (!check_forumperm($ForumID)) {
|
||||||
print json_encode(array('status' => 'failure'));
|
print json_encode(array('status' => 'failure'));
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
//Post links utilize the catalogue & key params to prevent issues with custom posts per page
|
//Post links utilize the catalogue & key params to prevent issues with custom posts per page
|
||||||
if($ThreadInfo['Posts'] > $PerPage) {
|
if ($ThreadInfo['Posts'] > $PerPage) {
|
||||||
if(isset($_GET['post']) && is_number($_GET['post'])) {
|
if (isset($_GET['post']) && is_number($_GET['post'])) {
|
||||||
$PostNum = $_GET['post'];
|
$PostNum = $_GET['post'];
|
||||||
} elseif(isset($_GET['postid']) && is_number($_GET['postid'])) {
|
} elseif (isset($_GET['postid']) && is_number($_GET['postid'])) {
|
||||||
$DB->query("SELECT COUNT(ID) FROM forums_posts WHERE TopicID = $ThreadID AND ID <= $_GET[postid]");
|
$DB->query("SELECT COUNT(ID) FROM forums_posts WHERE TopicID = $ThreadID AND ID <= $_GET[postid]");
|
||||||
list($PostNum) = $DB->next_record();
|
list($PostNum) = $DB->next_record();
|
||||||
} else {
|
} else {
|
||||||
@ -74,13 +72,13 @@
|
|||||||
$PostNum = 1;
|
$PostNum = 1;
|
||||||
}
|
}
|
||||||
list($Page,$Limit) = Format::page_limit($PerPage, min($ThreadInfo['Posts'],$PostNum));
|
list($Page,$Limit) = Format::page_limit($PerPage, min($ThreadInfo['Posts'],$PostNum));
|
||||||
if(($Page-1)*$PerPage > $ThreadInfo['Posts']) {
|
if (($Page - 1) * $PerPage > $ThreadInfo['Posts']) {
|
||||||
$Page = ceil($ThreadInfo['Posts']/$PerPage);
|
$Page = ceil($ThreadInfo['Posts']/$PerPage);
|
||||||
}
|
}
|
||||||
list($CatalogueID,$CatalogueLimit) = Format::catalogue_limit($Page,$PerPage,THREAD_CATALOGUE);
|
list($CatalogueID,$CatalogueLimit) = Format::catalogue_limit($Page,$PerPage,THREAD_CATALOGUE);
|
||||||
|
|
||||||
// Cache catalogue from which the page is selected, allows block caches and future ability to specify posts per page
|
// Cache catalogue from which the page is selected, allows block caches and future ability to specify posts per page
|
||||||
if(!$Catalogue = $Cache->get_value('thread_'.$ThreadID.'_catalogue_'.$CatalogueID)) {
|
if (!$Catalogue = $Cache->get_value('thread_'.$ThreadID.'_catalogue_'.$CatalogueID)) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
p.ID,
|
p.ID,
|
||||||
p.AuthorID,
|
p.AuthorID,
|
||||||
@ -102,14 +100,14 @@
|
|||||||
$LastPost = end($Thread);
|
$LastPost = end($Thread);
|
||||||
$LastPost = $LastPost['ID'];
|
$LastPost = $LastPost['ID'];
|
||||||
reset($Thread);
|
reset($Thread);
|
||||||
if($ThreadInfo['Posts'] <= $PerPage*$Page && $ThreadInfo['StickyPostID'] > $LastPost) {
|
if ($ThreadInfo['Posts'] <= $PerPage * $Page && $ThreadInfo['StickyPostID'] > $LastPost) {
|
||||||
$LastPost = $ThreadInfo['StickyPostID'];
|
$LastPost = $ThreadInfo['StickyPostID'];
|
||||||
}
|
}
|
||||||
//Handle last read
|
//Handle last read
|
||||||
if (!$ThreadInfo['IsLocked'] || $ThreadInfo['IsSticky']) {
|
if (!$ThreadInfo['IsLocked'] || $ThreadInfo['IsSticky']) {
|
||||||
$DB->query("SELECT PostID From forums_last_read_topics WHERE UserID='$LoggedUser[ID]' AND TopicID='$ThreadID'");
|
$DB->query("SELECT PostID From forums_last_read_topics WHERE UserID='$LoggedUser[ID]' AND TopicID='$ThreadID'");
|
||||||
list($LastRead) = $DB->next_record();
|
list($LastRead) = $DB->next_record();
|
||||||
if($LastRead < $LastPost) {
|
if ($LastRead < $LastPost) {
|
||||||
$DB->query("INSERT INTO forums_last_read_topics
|
$DB->query("INSERT INTO forums_last_read_topics
|
||||||
(UserID, TopicID, PostID) VALUES
|
(UserID, TopicID, PostID) VALUES
|
||||||
('$LoggedUser[ID]', '".$ThreadID ."', '".db_string($LastPost)."')
|
('$LoggedUser[ID]', '".$ThreadID ."', '".db_string($LastPost)."')
|
||||||
@ -119,17 +117,17 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Handle subscriptions
|
//Handle subscriptions
|
||||||
if(($UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) === FALSE) {
|
if (($UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) === false) {
|
||||||
$DB->query("SELECT TopicID FROM users_subscriptions WHERE UserID = '$LoggedUser[ID]'");
|
$DB->query("SELECT TopicID FROM users_subscriptions WHERE UserID = '$LoggedUser[ID]'");
|
||||||
$UserSubscriptions = $DB->collect(0);
|
$UserSubscriptions = $DB->collect(0);
|
||||||
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(empty($UserSubscriptions)) {
|
if (empty($UserSubscriptions)) {
|
||||||
$UserSubscriptions = array();
|
$UserSubscriptions = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(in_array($ThreadID, $UserSubscriptions)) {
|
if (in_array($ThreadID, $UserSubscriptions)) {
|
||||||
$Cache->delete_value('subscriptions_user_new_'.$LoggedUser['ID']);
|
$Cache->delete_value('subscriptions_user_new_'.$LoggedUser['ID']);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -148,7 +146,7 @@
|
|||||||
$Votes[$Key] = $Value;
|
$Votes[$Key] = $Value;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach(array_keys($Answers) as $i) {
|
foreach (array_keys($Answers) as $i) {
|
||||||
if (!isset($Votes[$i])) {
|
if (!isset($Votes[$i])) {
|
||||||
$Votes[$i] = 0;
|
$Votes[$i] = 0;
|
||||||
}
|
}
|
||||||
@ -171,7 +169,7 @@
|
|||||||
if (!empty($UserResponse) && $UserResponse != 0) {
|
if (!empty($UserResponse) && $UserResponse != 0) {
|
||||||
$Answers[$UserResponse] = '» '.$Answers[$UserResponse];
|
$Answers[$UserResponse] = '» '.$Answers[$UserResponse];
|
||||||
} else {
|
} else {
|
||||||
if(!empty($UserResponse) && $RevealVoters) {
|
if (!empty($UserResponse) && $RevealVoters) {
|
||||||
$Answers[$UserResponse] = '» '.$Answers[$UserResponse];
|
$Answers[$UserResponse] = '» '.$Answers[$UserResponse];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -208,11 +206,11 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Sqeeze in stickypost
|
//Sqeeze in stickypost
|
||||||
if($ThreadInfo['StickyPostID']) {
|
if ($ThreadInfo['StickyPostID']) {
|
||||||
if($ThreadInfo['StickyPostID'] != $Thread[0]['ID']) {
|
if ($ThreadInfo['StickyPostID'] != $Thread[0]['ID']) {
|
||||||
array_unshift($Thread, $ThreadInfo['StickyPost']);
|
array_unshift($Thread, $ThreadInfo['StickyPost']);
|
||||||
}
|
}
|
||||||
if($ThreadInfo['StickyPostID'] != $Thread[count($Thread)-1]['ID']) {
|
if ($ThreadInfo['StickyPostID'] != $Thread[count($Thread)-1]['ID']) {
|
||||||
$Thread[] = $ThreadInfo['StickyPost'];
|
$Thread[] = $ThreadInfo['StickyPost'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -72,7 +72,7 @@
|
|||||||
|
|
||||||
// Subscriptions
|
// Subscriptions
|
||||||
$NewSubscriptions = $Cache->get_value('subscriptions_user_new_' . $LoggedUser['ID']);
|
$NewSubscriptions = $Cache->get_value('subscriptions_user_new_' . $LoggedUser['ID']);
|
||||||
if ($NewSubscriptions === FALSE) {
|
if ($NewSubscriptions === false) {
|
||||||
if ($LoggedUser['CustomForums']) {
|
if ($LoggedUser['CustomForums']) {
|
||||||
unset($LoggedUser['CustomForums']['']);
|
unset($LoggedUser['CustomForums']['']);
|
||||||
$RestrictedForums = implode("','", array_keys($LoggedUser['CustomForums'], 0));
|
$RestrictedForums = implode("','", array_keys($LoggedUser['CustomForums'], 0));
|
||||||
|
@ -58,7 +58,7 @@
|
|||||||
// our life just got a bit easier. We're only tracking paired votes on upvotes.
|
// our life just got a bit easier. We're only tracking paired votes on upvotes.
|
||||||
if ($Type == 'Up') {
|
if ($Type == 'Up') {
|
||||||
$VotePairs = $Cache->get_value('vote_pairs_'.$GroupID, true);
|
$VotePairs = $Cache->get_value('vote_pairs_'.$GroupID, true);
|
||||||
if ($VotePairs !== FALSE) {
|
if ($VotePairs !== false) {
|
||||||
foreach ($UserVotes as $Vote) {
|
foreach ($UserVotes as $Vote) {
|
||||||
if ($Vote['GroupID'] == $GroupID) {
|
if ($Vote['GroupID'] == $GroupID) {
|
||||||
continue;
|
continue;
|
||||||
@ -91,7 +91,7 @@
|
|||||||
}
|
}
|
||||||
// Again, if the cache key is not set, move along
|
// Again, if the cache key is not set, move along
|
||||||
$VotePairs = $Cache->get_value('vote_pairs_'.$VGID, true);
|
$VotePairs = $Cache->get_value('vote_pairs_'.$VGID, true);
|
||||||
if ($VotePairs !== FALSE) {
|
if ($VotePairs !== false) {
|
||||||
// Go through all of the other albums paired to this one, and update
|
// Go through all of the other albums paired to this one, and update
|
||||||
// this group's entry in their vote_pairs keys
|
// this group's entry in their vote_pairs keys
|
||||||
if (isset($VotePairs[$GroupID])) {
|
if (isset($VotePairs[$GroupID])) {
|
||||||
@ -131,15 +131,15 @@
|
|||||||
$Cache->cache_value('votes_'.$GroupID, $GroupVotes);
|
$Cache->cache_value('votes_'.$GroupID, $GroupVotes);
|
||||||
|
|
||||||
$DB->query("UPDATE torrents_votes SET Total = GREATEST(0, Total - 1),
|
$DB->query("UPDATE torrents_votes SET Total = GREATEST(0, Total - 1),
|
||||||
Score = IFNULL(binomial_ci(GREATEST(0,Ups".($Type=='Up'?'-1':'')."),GREATEST(0, Total)),0)".
|
Score = IFNULL(binomial_ci(GREATEST(0,Ups".($Type == 'Up' ? '-1' : '')."),GREATEST(0, Total)),0)".
|
||||||
($Type=='Up'?', Ups = GREATEST(0, Ups - 1)':'')."
|
($Type == 'Up' ? ', Ups = GREATEST(0, Ups - 1)' : '')."
|
||||||
WHERE GroupID=$GroupID");
|
WHERE GroupID=$GroupID");
|
||||||
// Update paired cache keys
|
// Update paired cache keys
|
||||||
// First update this album's paired votes. If this keys is magically not set,
|
// First update this album's paired votes. If this keys is magically not set,
|
||||||
// our life just got a bit easier. We're only tracking paired votes on upvotes.
|
// our life just got a bit easier. We're only tracking paired votes on upvotes.
|
||||||
if ($Type == 'Up') {
|
if ($Type == 'Up') {
|
||||||
$VotePairs = $Cache->get_value('vote_pairs_'.$GroupID, true);
|
$VotePairs = $Cache->get_value('vote_pairs_'.$GroupID, true);
|
||||||
if ($VotePairs !== FALSE) {
|
if ($VotePairs !== false) {
|
||||||
foreach ($UserVotes as $Vote) {
|
foreach ($UserVotes as $Vote) {
|
||||||
if (isset($VotePairs[$Vote['GroupID']])) {
|
if (isset($VotePairs[$Vote['GroupID']])) {
|
||||||
if ($VotePairs[$Vote['GroupID']]['Total'] == 0) {
|
if ($VotePairs[$Vote['GroupID']]['Total'] == 0) {
|
||||||
@ -172,7 +172,7 @@
|
|||||||
}
|
}
|
||||||
// Again, if the cache key is not set, move along
|
// Again, if the cache key is not set, move along
|
||||||
$VotePairs = $Cache->get_value('vote_pairs_'.$VGID, true);
|
$VotePairs = $Cache->get_value('vote_pairs_'.$VGID, true);
|
||||||
if ($VotePairs !== FALSE) {
|
if ($VotePairs !== false) {
|
||||||
if (isset($VotePairs[$GroupID])) {
|
if (isset($VotePairs[$GroupID])) {
|
||||||
if ($VotePairs[$GroupID]['Total'] == 0) {
|
if ($VotePairs[$GroupID]['Total'] == 0) {
|
||||||
// Something is screwy
|
// Something is screwy
|
||||||
@ -198,4 +198,4 @@
|
|||||||
echo 'success-down';
|
echo 'success-down';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
@ -4,15 +4,15 @@
|
|||||||
User post history page
|
User post history page
|
||||||
*/
|
*/
|
||||||
|
|
||||||
function error_out($reason = "") {
|
function error_out($reason = '') {
|
||||||
$error = array('status' => 'failure');
|
$error = array('status' => 'failure');
|
||||||
if ($reason != "")
|
if ($reason != '')
|
||||||
$error['reason'] = $reason;
|
$error['reason'] = $reason;
|
||||||
print $error;
|
print $error;
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!empty($LoggedUser['DisableForums'])) {
|
if (!empty($LoggedUser['DisableForums'])) {
|
||||||
error_out("You do not have access to the forums!");
|
error_out("You do not have access to the forums!");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -22,7 +22,7 @@ function error_out($reason = "") {
|
|||||||
|
|
||||||
|
|
||||||
$UserID = empty($_GET['userid']) ? $LoggedUser['ID'] : $_GET['userid'];
|
$UserID = empty($_GET['userid']) ? $LoggedUser['ID'] : $_GET['userid'];
|
||||||
if(!is_number($UserID)){
|
if (!is_number($UserID)) {
|
||||||
error_out("User does not exist!");
|
error_out("User does not exist!");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34,7 +34,7 @@ function error_out($reason = "") {
|
|||||||
|
|
||||||
list($Page,$Limit) = Format::page_limit($PerPage);
|
list($Page,$Limit) = Format::page_limit($PerPage);
|
||||||
|
|
||||||
if(($UserInfo = $Cache->get_value('user_info_'.$UserID)) === FALSE) {
|
if (($UserInfo = $Cache->get_value('user_info_'.$UserID)) === false) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
m.Username,
|
m.Username,
|
||||||
m.Enabled,
|
m.Enabled,
|
||||||
@ -46,7 +46,7 @@ function error_out($reason = "") {
|
|||||||
JOIN users_info AS i ON i.UserID = m.ID
|
JOIN users_info AS i ON i.UserID = m.ID
|
||||||
WHERE m.ID = $UserID");
|
WHERE m.ID = $UserID");
|
||||||
|
|
||||||
if($DB->record_count() == 0){ // If user doesn't exist
|
if ($DB->record_count() == 0){ // If user doesn't exist
|
||||||
error_out("User does not exist!");
|
error_out("User does not exist!");
|
||||||
}
|
}
|
||||||
list($Username, $Enabled, $Title, $Avatar, $Donor, $Warned) = $DB->next_record();
|
list($Username, $Enabled, $Title, $Avatar, $Donor, $Warned) = $DB->next_record();
|
||||||
@ -54,24 +54,24 @@ function error_out($reason = "") {
|
|||||||
extract(array_intersect_key($UserInfo, array_flip(array('Username', 'Enabled', 'Title', 'Avatar', 'Donor', 'Warned'))));
|
extract(array_intersect_key($UserInfo, array_flip(array('Username', 'Enabled', 'Title', 'Avatar', 'Donor', 'Warned'))));
|
||||||
}
|
}
|
||||||
|
|
||||||
if(check_perms('site_proxy_images') && !empty($Avatar)) {
|
if (check_perms('site_proxy_images') && !empty($Avatar)) {
|
||||||
$Avatar = 'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?c=1&i='.urlencode($Avatar);
|
$Avatar = 'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?c=1&i='.urlencode($Avatar);
|
||||||
}
|
}
|
||||||
|
|
||||||
if($LoggedUser['CustomForums']) {
|
if ($LoggedUser['CustomForums']) {
|
||||||
unset($LoggedUser['CustomForums']['']);
|
unset($LoggedUser['CustomForums']['']);
|
||||||
$RestrictedForums = implode("','", array_keys($LoggedUser['CustomForums'], 0));
|
$RestrictedForums = implode("','", array_keys($LoggedUser['CustomForums'], 0));
|
||||||
}
|
}
|
||||||
$ViewingOwn = ($UserID == $LoggedUser['ID']);
|
$ViewingOwn = ($UserID == $LoggedUser['ID']);
|
||||||
$ShowUnread = ($ViewingOwn && (!isset($_GET['showunread']) || !!$_GET['showunread']));
|
$ShowUnread = ($ViewingOwn && (!isset($_GET['showunread']) || !!$_GET['showunread']));
|
||||||
$ShowGrouped = ($ViewingOwn && (!isset($_GET['group']) || !!$_GET['group']));
|
$ShowGrouped = ($ViewingOwn && (!isset($_GET['group']) || !!$_GET['group']));
|
||||||
if($ShowGrouped) {
|
if ($ShowGrouped) {
|
||||||
$sql = 'SELECT
|
$sql = 'SELECT
|
||||||
SQL_CALC_FOUND_ROWS
|
SQL_CALC_FOUND_ROWS
|
||||||
MAX(p.ID) AS ID
|
MAX(p.ID) AS ID
|
||||||
FROM forums_posts AS p
|
FROM forums_posts AS p
|
||||||
LEFT JOIN forums_topics AS t ON t.ID = p.TopicID';
|
LEFT JOIN forums_topics AS t ON t.ID = p.TopicID';
|
||||||
if($ShowUnread) {
|
if ($ShowUnread) {
|
||||||
$sql.='
|
$sql.='
|
||||||
LEFT JOIN forums_last_read_topics AS l ON l.TopicID = t.ID AND l.UserID = '.$LoggedUser['ID'];
|
LEFT JOIN forums_last_read_topics AS l ON l.TopicID = t.ID AND l.UserID = '.$LoggedUser['ID'];
|
||||||
}
|
}
|
||||||
@ -79,17 +79,17 @@ function error_out($reason = "") {
|
|||||||
LEFT JOIN forums AS f ON f.ID = t.ForumID
|
LEFT JOIN forums AS f ON f.ID = t.ForumID
|
||||||
WHERE p.AuthorID = '.$UserID.'
|
WHERE p.AuthorID = '.$UserID.'
|
||||||
AND ((f.MinClassRead <= '.$LoggedUser['EffectiveClass'];
|
AND ((f.MinClassRead <= '.$LoggedUser['EffectiveClass'];
|
||||||
if(!empty($RestrictedForums)) {
|
if (!empty($RestrictedForums)) {
|
||||||
$sql.='
|
$sql.='
|
||||||
AND f.ID NOT IN (\''.$RestrictedForums.'\')';
|
AND f.ID NOT IN (\''.$RestrictedForums.'\')';
|
||||||
}
|
}
|
||||||
$sql .= ')';
|
$sql .= ')';
|
||||||
if(!empty($PermittedForums)) {
|
if (!empty($PermittedForums)) {
|
||||||
$sql.='
|
$sql.='
|
||||||
OR f.ID IN (\''.$PermittedForums.'\')';
|
OR f.ID IN (\''.$PermittedForums.'\')';
|
||||||
}
|
}
|
||||||
$sql .= ')';
|
$sql .= ')';
|
||||||
if($ShowUnread) {
|
if ($ShowUnread) {
|
||||||
$sql .= '
|
$sql .= '
|
||||||
AND ((t.IsLocked=\'0\' OR t.IsSticky=\'1\')
|
AND ((t.IsLocked=\'0\' OR t.IsSticky=\'1\')
|
||||||
AND (l.PostID<t.LastPostID OR l.PostID IS NULL))';
|
AND (l.PostID<t.LastPostID OR l.PostID IS NULL))';
|
||||||
@ -101,7 +101,7 @@ function error_out($reason = "") {
|
|||||||
$DB->query("SELECT FOUND_ROWS()");
|
$DB->query("SELECT FOUND_ROWS()");
|
||||||
list($Results) = $DB->next_record();
|
list($Results) = $DB->next_record();
|
||||||
|
|
||||||
if($Results > $PerPage*($Page-1)) {
|
if ($Results > $PerPage * ($Page - 1)) {
|
||||||
$DB->set_query_id($PostIDs);
|
$DB->set_query_id($PostIDs);
|
||||||
$PostIDs = $DB->collect('ID');
|
$PostIDs = $DB->collect('ID');
|
||||||
$sql = 'SELECT
|
$sql = 'SELECT
|
||||||
@ -131,7 +131,7 @@ function error_out($reason = "") {
|
|||||||
} else {
|
} else {
|
||||||
$sql = 'SELECT
|
$sql = 'SELECT
|
||||||
SQL_CALC_FOUND_ROWS';
|
SQL_CALC_FOUND_ROWS';
|
||||||
if($ShowGrouped) {
|
if ($ShowGrouped) {
|
||||||
$sql.=' * FROM (SELECT';
|
$sql.=' * FROM (SELECT';
|
||||||
}
|
}
|
||||||
$sql .= '
|
$sql .= '
|
||||||
@ -144,7 +144,7 @@ function error_out($reason = "") {
|
|||||||
p.TopicID,
|
p.TopicID,
|
||||||
t.Title,
|
t.Title,
|
||||||
t.LastPostID,';
|
t.LastPostID,';
|
||||||
if($UserID == $LoggedUser['ID']) {
|
if ($UserID == $LoggedUser['ID']) {
|
||||||
$sql .= '
|
$sql .= '
|
||||||
l.PostID AS LastRead,';
|
l.PostID AS LastRead,';
|
||||||
}
|
}
|
||||||
@ -161,12 +161,12 @@ function error_out($reason = "") {
|
|||||||
WHERE p.AuthorID = '.$UserID.'
|
WHERE p.AuthorID = '.$UserID.'
|
||||||
AND f.MinClassRead <= '.$LoggedUser['EffectiveClass'];
|
AND f.MinClassRead <= '.$LoggedUser['EffectiveClass'];
|
||||||
|
|
||||||
if(!empty($RestrictedForums)) {
|
if (!empty($RestrictedForums)) {
|
||||||
$sql.='
|
$sql.='
|
||||||
AND f.ID NOT IN (\''.$RestrictedForums.'\')';
|
AND f.ID NOT IN (\''.$RestrictedForums.'\')';
|
||||||
}
|
}
|
||||||
|
|
||||||
if($ShowUnread) {
|
if ($ShowUnread) {
|
||||||
$sql.='
|
$sql.='
|
||||||
AND ((t.IsLocked=\'0\' OR t.IsSticky=\'1\') AND (l.PostID<t.LastPostID OR l.PostID IS NULL)) ';
|
AND ((t.IsLocked=\'0\' OR t.IsSticky=\'1\') AND (l.PostID<t.LastPostID OR l.PostID IS NULL)) ';
|
||||||
}
|
}
|
||||||
@ -174,7 +174,7 @@ function error_out($reason = "") {
|
|||||||
$sql .= '
|
$sql .= '
|
||||||
ORDER BY p.ID DESC';
|
ORDER BY p.ID DESC';
|
||||||
|
|
||||||
if($ShowGrouped) {
|
if ($ShowGrouped) {
|
||||||
$sql.='
|
$sql.='
|
||||||
) AS sub
|
) AS sub
|
||||||
GROUP BY TopicID ORDER BY ID DESC';
|
GROUP BY TopicID ORDER BY ID DESC';
|
||||||
@ -190,7 +190,7 @@ function error_out($reason = "") {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$JsonResults = array();
|
$JsonResults = array();
|
||||||
while(list($PostID, $AddedTime, $Body, $EditedUserID, $EditedTime, $EditedUsername, $TopicID, $ThreadTitle, $LastPostID, $LastRead, $Locked, $Sticky) = $DB->next_record()){
|
while (list($PostID, $AddedTime, $Body, $EditedUserID, $EditedTime, $EditedUsername, $TopicID, $ThreadTitle, $LastPostID, $LastRead, $Locked, $Sticky) = $DB->next_record()) {
|
||||||
$JsonResults[] = array(
|
$JsonResults[] = array(
|
||||||
'postId' => (int) $PostID,
|
'postId' => (int) $PostID,
|
||||||
'topicId' => (int) $TopicID,
|
'topicId' => (int) $TopicID,
|
||||||
|
@ -1,26 +1,30 @@
|
|||||||
<?
|
<?
|
||||||
authorize();
|
authorize();
|
||||||
if(!check_perms('site_torrents_notify')) { error(403); }
|
if (!check_perms('site_torrents_notify')) {
|
||||||
|
error(403);
|
||||||
|
}
|
||||||
$ArtistID = $_GET['artistid'];
|
$ArtistID = $_GET['artistid'];
|
||||||
if(!is_number($ArtistID)) { error(0); }
|
if (!is_number($ArtistID)) {
|
||||||
|
error(0);
|
||||||
|
}
|
||||||
|
|
||||||
$DB->query("SELECT GROUP_CONCAT(Name SEPARATOR '|') FROM artists_alias WHERE ArtistID = '$ArtistID' AND Redirect = 0 GROUP BY ArtistID");
|
$DB->query("SELECT GROUP_CONCAT(Name SEPARATOR '|') FROM artists_alias WHERE ArtistID = '$ArtistID' AND Redirect = 0 GROUP BY ArtistID");
|
||||||
list($ArtistAliases) = $DB->next_record(MYSQLI_NUM, FALSE);
|
list($ArtistAliases) = $DB->next_record(MYSQLI_NUM, FALSE);
|
||||||
|
|
||||||
$Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID']);
|
$Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID']);
|
||||||
if(empty($Notify)) {
|
if (empty($Notify)) {
|
||||||
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE Label='Artist notifications' AND UserID='$LoggedUser[ID]' ORDER BY ID LIMIT 1");
|
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE Label='Artist notifications' AND UserID='$LoggedUser[ID]' ORDER BY ID LIMIT 1");
|
||||||
} else {
|
} else {
|
||||||
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE ID='$Notify[ID]'");
|
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE ID='$Notify[ID]'");
|
||||||
}
|
}
|
||||||
if(empty($Notify) && $DB->record_count() == 0) {
|
if (empty($Notify) && $DB->record_count() == 0) {
|
||||||
$DB->query("INSERT INTO users_notify_filters (UserID, Label, Artists) VALUES ('$LoggedUser[ID]', 'Artist notifications', '|".db_string($ArtistAliases)."|')");
|
$DB->query("INSERT INTO users_notify_filters (UserID, Label, Artists) VALUES ('$LoggedUser[ID]', 'Artist notifications', '|".db_string($ArtistAliases)."|')");
|
||||||
$FilterID = $DB->inserted_id();
|
$FilterID = $DB->inserted_id();
|
||||||
$Cache->delete_value('notify_filters_'.$LoggedUser['ID']);
|
$Cache->delete_value('notify_filters_'.$LoggedUser['ID']);
|
||||||
$Cache->delete_value('notify_artists_'.$LoggedUser['ID']);
|
$Cache->delete_value('notify_artists_'.$LoggedUser['ID']);
|
||||||
} else {
|
} else {
|
||||||
list($ID, $ArtistNames) = $DB->next_record(MYSQLI_NUM, FALSE);
|
list($ID, $ArtistNames) = $DB->next_record(MYSQLI_NUM, FALSE);
|
||||||
if(stripos($ArtistNames,$ArtistAliases) === FALSE) {
|
if (stripos($ArtistNames,$ArtistAliases) === false) {
|
||||||
$ArtistNames.=$ArtistAliases.'|';
|
$ArtistNames.=$ArtistAliases.'|';
|
||||||
$DB->query("UPDATE users_notify_filters SET Artists='".db_string($ArtistNames)."' WHERE ID='$ID'");
|
$DB->query("UPDATE users_notify_filters SET Artists='".db_string($ArtistNames)."' WHERE ID='$ID'");
|
||||||
$Cache->delete_value('notify_filters_'.$LoggedUser['ID']);
|
$Cache->delete_value('notify_filters_'.$LoggedUser['ID']);
|
||||||
|
@ -1,22 +1,26 @@
|
|||||||
<?
|
<?
|
||||||
authorize();
|
authorize();
|
||||||
if(!check_perms('site_torrents_notify')) { error(403); }
|
if (!check_perms('site_torrents_notify')) {
|
||||||
|
error(403);
|
||||||
|
}
|
||||||
$ArtistID = $_GET['artistid'];
|
$ArtistID = $_GET['artistid'];
|
||||||
if(!is_number($ArtistID)) { error(0); }
|
if (!is_number($ArtistID)) {
|
||||||
|
error(0);
|
||||||
|
}
|
||||||
|
|
||||||
if(($Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID'])) === FALSE) {
|
if (($Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID'])) === false) {
|
||||||
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE Label='Artist notifications' AND UserID='$LoggedUser[ID]' ORDER BY ID LIMIT 1");
|
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE Label='Artist notifications' AND UserID='$LoggedUser[ID]' ORDER BY ID LIMIT 1");
|
||||||
} else {
|
} else {
|
||||||
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE ID='$Notify[ID]'");
|
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE ID='$Notify[ID]'");
|
||||||
}
|
}
|
||||||
list($ID,$Artists) = $DB->next_record(MYSQLI_NUM, FALSE);
|
list($ID,$Artists) = $DB->next_record(MYSQLI_NUM, FALSE);
|
||||||
$DB->query("SELECT Name FROM artists_alias WHERE ArtistID = '$ArtistID' AND Redirect=0");
|
$DB->query("SELECT Name FROM artists_alias WHERE ArtistID = '$ArtistID' AND Redirect=0");
|
||||||
while(list($Alias) = $DB->next_record(MYSQLI_NUM, FALSE)) {
|
while (list($Alias) = $DB->next_record(MYSQLI_NUM, FALSE)) {
|
||||||
while(stripos($Artists, '|'.$Alias.'|') !== FALSE) {
|
while (stripos($Artists, '|'.$Alias.'|') !== false) {
|
||||||
$Artists = str_ireplace('|'.$Alias.'|', '|', $Artists);
|
$Artists = str_ireplace('|'.$Alias.'|', '|', $Artists);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if($Artists == '|') {
|
if ($Artists == '|') {
|
||||||
$DB->query("DELETE FROM users_notify_filters WHERE ID=$ID");
|
$DB->query("DELETE FROM users_notify_filters WHERE ID=$ID");
|
||||||
} else {
|
} else {
|
||||||
$DB->query("UPDATE users_notify_filters SET Artists='".db_string($Artists)."' WHERE ID='$ID'");
|
$DB->query("UPDATE users_notify_filters SET Artists='".db_string($Artists)."' WHERE ID='$ID'");
|
||||||
|
@ -65,12 +65,12 @@
|
|||||||
<span style="float: right">
|
<span style="float: right">
|
||||||
<?
|
<?
|
||||||
if (check_perms('site_torrents_notify')) {
|
if (check_perms('site_torrents_notify')) {
|
||||||
if (($Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID'])) === FALSE) {
|
if (($Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID'])) === false) {
|
||||||
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE UserID='$LoggedUser[ID]' AND Label='Artist notifications' LIMIT 1");
|
$DB->query("SELECT ID, Artists FROM users_notify_filters WHERE UserID='$LoggedUser[ID]' AND Label='Artist notifications' LIMIT 1");
|
||||||
$Notify = $DB->next_record(MYSQLI_ASSOC);
|
$Notify = $DB->next_record(MYSQLI_ASSOC);
|
||||||
$Cache->cache_value('notify_artists_'.$LoggedUser['ID'], $Notify, 0);
|
$Cache->cache_value('notify_artists_'.$LoggedUser['ID'], $Notify, 0);
|
||||||
}
|
}
|
||||||
if (stripos($Notify['Artists'], '|'.$Name.'|') === FALSE) {
|
if (stripos($Notify['Artists'], '|'.$Name.'|') === false) {
|
||||||
?>
|
?>
|
||||||
<a href="artist.php?action=notify&artistid=<?=$ArtistID?>&auth=<?=$LoggedUser['AuthKey']?>" class="brackets">Notify of new uploads</a>
|
<a href="artist.php?action=notify&artistid=<?=$ArtistID?>&auth=<?=$LoggedUser['AuthKey']?>" class="brackets">Notify of new uploads</a>
|
||||||
<?
|
<?
|
||||||
|
@ -21,14 +21,14 @@ function compare($X, $Y){
|
|||||||
|
|
||||||
$Data = $Cache->get_value('collage_'.$CollageID);
|
$Data = $Cache->get_value('collage_'.$CollageID);
|
||||||
|
|
||||||
if($Data) {
|
if ($Data) {
|
||||||
if (!is_array($Data)) {
|
if (!is_array($Data)) {
|
||||||
$Data = unserialize($Data);
|
$Data = unserialize($Data);
|
||||||
}
|
}
|
||||||
list($K, list($Name, $Description, , , $CommentList, $Deleted, $CollageCategoryID, $CreatorID, $Locked, $MaxGroups, $MaxGroupsPerUser)) = each($Data);
|
list($K, list($Name, $Description, , , $CommentList, $Deleted, $CollageCategoryID, $CreatorID, $Locked, $MaxGroups, $MaxGroupsPerUser)) = each($Data);
|
||||||
} else {
|
} else {
|
||||||
$DB->query("SELECT Name, Description, UserID, Deleted, CategoryID, Locked, MaxGroups, MaxGroupsPerUser FROM collages WHERE ID='$CollageID'");
|
$DB->query("SELECT Name, Description, UserID, Deleted, CategoryID, Locked, MaxGroups, MaxGroupsPerUser FROM collages WHERE ID='$CollageID'");
|
||||||
if($DB->record_count() > 0) {
|
if ($DB->record_count() > 0) {
|
||||||
list($Name, $Description, $CreatorID, $Deleted, $CollageCategoryID, $Locked, $MaxGroups, $MaxGroupsPerUser) = $DB->next_record();
|
list($Name, $Description, $CreatorID, $Deleted, $CollageCategoryID, $Locked, $MaxGroups, $MaxGroupsPerUser) = $DB->next_record();
|
||||||
$TorrentList='';
|
$TorrentList='';
|
||||||
$CollageList='';
|
$CollageList='';
|
||||||
@ -37,29 +37,29 @@ function compare($X, $Y){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if($Deleted == '1') {
|
if ($Deleted == '1') {
|
||||||
header('Location: log.php?search=Collage+'.$CollageID);
|
header('Location: log.php?search=Collage+'.$CollageID);
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
if($CollageCategoryID == 0 && !check_perms('site_collages_delete')) {
|
if ($CollageCategoryID == 0 && !check_perms('site_collages_delete')) {
|
||||||
if(!check_perms('site_collages_personal') || $CreatorID != $LoggedUser['ID']) {
|
if (!check_perms('site_collages_personal') || $CreatorID != $LoggedUser['ID']) {
|
||||||
$PreventAdditions = true;
|
$PreventAdditions = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Handle subscriptions
|
//Handle subscriptions
|
||||||
if(($CollageSubscriptions = $Cache->get_value('collage_subs_user_'.$LoggedUser['ID'])) === FALSE) {
|
if (($CollageSubscriptions = $Cache->get_value('collage_subs_user_'.$LoggedUser['ID'])) === false) {
|
||||||
$DB->query("SELECT CollageID FROM users_collage_subs WHERE UserID = '$LoggedUser[ID]'");
|
$DB->query("SELECT CollageID FROM users_collage_subs WHERE UserID = '$LoggedUser[ID]'");
|
||||||
$CollageSubscriptions = $DB->collect(0);
|
$CollageSubscriptions = $DB->collect(0);
|
||||||
$Cache->cache_value('collage_subs_user_'.$LoggedUser['ID'],$CollageSubscriptions,0);
|
$Cache->cache_value('collage_subs_user_'.$LoggedUser['ID'],$CollageSubscriptions,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(empty($CollageSubscriptions)) {
|
if (empty($CollageSubscriptions)) {
|
||||||
$CollageSubscriptions = array();
|
$CollageSubscriptions = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(in_array($CollageID, $CollageSubscriptions)) {
|
if (in_array($CollageID, $CollageSubscriptions)) {
|
||||||
$Cache->delete_value('collage_subs_user_new_'.$LoggedUser['ID']);
|
$Cache->delete_value('collage_subs_user_new_'.$LoggedUser['ID']);
|
||||||
}
|
}
|
||||||
$DB->query("UPDATE users_collage_subs SET LastVisit=NOW() WHERE UserID = ".$LoggedUser['ID']." AND CollageID=$CollageID");
|
$DB->query("UPDATE users_collage_subs SET LastVisit=NOW() WHERE UserID = ".$LoggedUser['ID']." AND CollageID=$CollageID");
|
||||||
@ -79,7 +79,7 @@ function compare($X, $Y){
|
|||||||
|
|
||||||
$GroupIDs = $DB->collect('GroupID');
|
$GroupIDs = $DB->collect('GroupID');
|
||||||
$CollageDataList = $DB->to_array('GroupID', MYSQLI_ASSOC);
|
$CollageDataList = $DB->to_array('GroupID', MYSQLI_ASSOC);
|
||||||
if(count($GroupIDs)>0) {
|
if (count($GroupIDs) > 0) {
|
||||||
$TorrentList = Torrents::get_groups($GroupIDs);
|
$TorrentList = Torrents::get_groups($GroupIDs);
|
||||||
$TorrentList = $TorrentList['matches'];
|
$TorrentList = $TorrentList['matches'];
|
||||||
} else {
|
} else {
|
||||||
@ -107,27 +107,28 @@ function compare($X, $Y){
|
|||||||
// Handle stats and stuff
|
// Handle stats and stuff
|
||||||
$Number++;
|
$Number++;
|
||||||
$NumGroups++;
|
$NumGroups++;
|
||||||
if($UserID == $LoggedUser['ID']) {
|
if ($UserID == $LoggedUser['ID']) {
|
||||||
$NumGroupsByUser++;
|
$NumGroupsByUser++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($ExtendedArtists[1]) || !empty($ExtendedArtists[4]) || !empty($ExtendedArtists[5]) || !empty($ExtendedArtists[6])) {
|
if (!empty($ExtendedArtists[1]) || !empty($ExtendedArtists[4]) || !empty($ExtendedArtists[5]) || !empty($ExtendedArtists[6])) {
|
||||||
$CountArtists = array_merge((array)$ExtendedArtists[1], (array)$ExtendedArtists[4], (array)$ExtendedArtists[5], (array)$ExtendedArtists[6]);
|
$CountArtists = array_merge((array)$ExtendedArtists[1], (array)$ExtendedArtists[4], (array)$ExtendedArtists[5], (array)$ExtendedArtists[6]);
|
||||||
} else{
|
} else {
|
||||||
$CountArtists = $GroupArtists;
|
$CountArtists = $GroupArtists;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($CountArtists) {
|
if ($CountArtists) {
|
||||||
foreach($CountArtists as $Artist) {
|
foreach ($CountArtists as $Artist) {
|
||||||
if (!isset($TopArtists[$Artist['id']]))
|
if (!isset($TopArtists[$Artist['id']])) {
|
||||||
$TopArtists[$Artist['id']] = array('name'=>$Artist['name'], 'count'=>1);
|
$TopArtists[$Artist['id']] = array('name'=>$Artist['name'], 'count'=>1);
|
||||||
else
|
} else {
|
||||||
$TopArtists[$Artist['id']]['count']++;
|
$TopArtists[$Artist['id']]['count']++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if($Username) {
|
if ($Username) {
|
||||||
if(!isset($Users[$UserID])) {
|
if (!isset($Users[$UserID])) {
|
||||||
$Users[$UserID] = array('name'=>$Username, 'count'=>1);
|
$Users[$UserID] = array('name'=>$Username, 'count'=>1);
|
||||||
} else {
|
} else {
|
||||||
$Users[$UserID]['count']++;
|
$Users[$UserID]['count']++;
|
||||||
@ -140,18 +141,18 @@ function compare($X, $Y){
|
|||||||
unset($ExtendedArtists[2]);
|
unset($ExtendedArtists[2]);
|
||||||
unset($ExtendedArtists[3]);
|
unset($ExtendedArtists[3]);
|
||||||
$DisplayName .= Artists::display_artists($ExtendedArtists);
|
$DisplayName .= Artists::display_artists($ExtendedArtists);
|
||||||
} elseif(count($GroupArtists)>0) {
|
} elseif (count($GroupArtists) > 0) {
|
||||||
$DisplayName .= Artists::display_artists(array('1'=>$GroupArtists));
|
$DisplayName .= Artists::display_artists(array('1'=>$GroupArtists));
|
||||||
}
|
}
|
||||||
|
|
||||||
$DisplayName .= '<a href="torrents.php?id='.$GroupID.'" title="View Torrent" dir="ltr">'.$GroupName.'</a>';
|
$DisplayName .= '<a href="torrents.php?id='.$GroupID.'" title="View Torrent" dir="ltr">'.$GroupName.'</a>';
|
||||||
if($GroupYear>0) { $DisplayName = $DisplayName. ' ['. $GroupYear .']';}
|
if ($GroupYear > 0) { $DisplayName = $DisplayName. ' ['. $GroupYear .']';}
|
||||||
if($GroupVanityHouse) { $DisplayName .= ' [<abbr title="This is a vanity house release">VH</abbr>]'; }
|
if ($GroupVanityHouse) { $DisplayName .= ' [<abbr title="This is a vanity house release">VH</abbr>]'; }
|
||||||
$SnatchedGroupClass = $GroupFlags['IsSnatched'] ? ' snatched_group' : '';
|
$SnatchedGroupClass = $GroupFlags['IsSnatched'] ? ' snatched_group' : '';
|
||||||
// Start an output buffer, so we can store this output in $TorrentTable
|
// Start an output buffer, so we can store this output in $TorrentTable
|
||||||
ob_start();
|
ob_start();
|
||||||
|
|
||||||
if(count($Torrents)>1 || $GroupCategoryID==1) {
|
if (count($Torrents) > 1 || $GroupCategoryID == 1) {
|
||||||
// Grouped torrents
|
// Grouped torrents
|
||||||
$ShowGroups = !(!empty($LoggedUser['TorrentGrouping']) && $LoggedUser['TorrentGrouping'] == 1);
|
$ShowGroups = !(!empty($LoggedUser['TorrentGrouping']) && $LoggedUser['TorrentGrouping'] == 1);
|
||||||
?>
|
?>
|
||||||
@ -186,7 +187,7 @@ function compare($X, $Y){
|
|||||||
}
|
}
|
||||||
$SnatchedTorrentClass = $Torrent['IsSnatched'] ? ' snatched_torrent' : '';
|
$SnatchedTorrentClass = $Torrent['IsSnatched'] ? ' snatched_torrent' : '';
|
||||||
|
|
||||||
if($Torrent['RemasterTitle'] != $LastRemasterTitle || $Torrent['RemasterYear'] != $LastRemasterYear ||
|
if ($Torrent['RemasterTitle'] != $LastRemasterTitle || $Torrent['RemasterYear'] != $LastRemasterYear ||
|
||||||
$Torrent['RemasterRecordLabel'] != $LastRemasterRecordLabel || $Torrent['RemasterCatalogueNumber'] != $LastRemasterCatalogueNumber || $FirstUnknown || $Torrent['Media'] != $LastMedia) {
|
$Torrent['RemasterRecordLabel'] != $LastRemasterRecordLabel || $Torrent['RemasterCatalogueNumber'] != $LastRemasterCatalogueNumber || $FirstUnknown || $Torrent['Media'] != $LastMedia) {
|
||||||
$EditionID++;
|
$EditionID++;
|
||||||
?>
|
?>
|
||||||
@ -273,16 +274,18 @@ function compare($X, $Y){
|
|||||||
unset($ExtendedArtists[2]);
|
unset($ExtendedArtists[2]);
|
||||||
unset($ExtendedArtists[3]);
|
unset($ExtendedArtists[3]);
|
||||||
$DisplayName .= Artists::display_artists($ExtendedArtists, false);
|
$DisplayName .= Artists::display_artists($ExtendedArtists, false);
|
||||||
} elseif(count($GroupArtists)>0) {
|
} elseif (count($GroupArtists) > 0) {
|
||||||
$DisplayName .= Artists::display_artists(array('1'=>$GroupArtists), false);
|
$DisplayName .= Artists::display_artists(array('1'=>$GroupArtists), false);
|
||||||
}
|
}
|
||||||
$DisplayName .= $GroupName;
|
$DisplayName .= $GroupName;
|
||||||
if($GroupYear>0) { $DisplayName = $DisplayName. ' ['. $GroupYear .']';}
|
if ($GroupYear > 0) {
|
||||||
|
$DisplayName = $DisplayName. ' ['. $GroupYear .']';
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
<li class="image_group_<?=$GroupID?>">
|
<li class="image_group_<?=$GroupID?>">
|
||||||
<a href="torrents.php?id=<?=$GroupID?>">
|
<a href="torrents.php?id=<?=$GroupID?>">
|
||||||
<? if($WikiImage) {
|
<? if ($WikiImage) {
|
||||||
if(check_perms('site_proxy_images')) {
|
if (check_perms('site_proxy_images')) {
|
||||||
$WikiImage = 'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?i='.urlencode($WikiImage);
|
$WikiImage = 'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?i='.urlencode($WikiImage);
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
@ -306,13 +309,13 @@ function compare($X, $Y){
|
|||||||
|
|
||||||
// Pad it out
|
// Pad it out
|
||||||
if ($NumGroups > $CollageCovers) {
|
if ($NumGroups > $CollageCovers) {
|
||||||
for ($i = $NumGroups + 1; $i <= ceil($NumGroups/$CollageCovers)*$CollageCovers; $i++) {
|
for ($i = $NumGroups + 1; $i <= ceil($NumGroups / $CollageCovers) * $CollageCovers; $i++) {
|
||||||
$Collage[] = '<li></li>';
|
$Collage[] = '<li></li>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
for ($i=0; $i < $NumGroups/$CollageCovers; $i++) {
|
for ($i = 0; $i < $NumGroups / $CollageCovers; $i++) {
|
||||||
$Groups = array_slice($Collage, $i*$CollageCovers, $CollageCovers);
|
$Groups = array_slice($Collage, $i*$CollageCovers, $CollageCovers);
|
||||||
$CollagePage = '';
|
$CollagePage = '';
|
||||||
foreach ($Groups as $Group) {
|
foreach ($Groups as $Group) {
|
||||||
@ -332,7 +335,7 @@ function compare($X, $Y){
|
|||||||
<a href="collages.php?action=new" class="brackets">New collage</a>
|
<a href="collages.php?action=new" class="brackets">New collage</a>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<br /><br />
|
<br /><br />
|
||||||
<? if(check_perms('site_collages_subscribe')) { ?>
|
<? if (check_perms('site_collages_subscribe')) { ?>
|
||||||
<a href="#" id="subscribelink<?=$CollageID?>" class="brackets" onclick="CollageSubscribe(<?=$CollageID?>);return false;"><?=(in_array($CollageID, $CollageSubscriptions) ? 'Unsubscribe' : 'Subscribe')?></a>
|
<a href="#" id="subscribelink<?=$CollageID?>" class="brackets" onclick="CollageSubscribe(<?=$CollageID?>);return false;"><?=(in_array($CollageID, $CollageSubscriptions) ? 'Unsubscribe' : 'Subscribe')?></a>
|
||||||
<? }
|
<? }
|
||||||
if (check_perms('site_collages_delete') || (check_perms('site_edit_wiki') && !$Locked)) { ?>
|
if (check_perms('site_collages_delete') || (check_perms('site_edit_wiki') && !$Locked)) { ?>
|
||||||
@ -340,7 +343,7 @@ function compare($X, $Y){
|
|||||||
<? } else { ?>
|
<? } else { ?>
|
||||||
<span class="brackets">Locked</span>
|
<span class="brackets">Locked</span>
|
||||||
<? }
|
<? }
|
||||||
if(Bookmarks::has_bookmarked('collage', $CollageID)) {
|
if (Bookmarks::has_bookmarked('collage', $CollageID)) {
|
||||||
?>
|
?>
|
||||||
<a href="#" id="bookmarklink_collage_<?=$CollageID?>" class="brackets" onclick="Unbookmark('collage', <?=$CollageID?>,'Bookmark');return false;">Remove bookmark</a>
|
<a href="#" id="bookmarklink_collage_<?=$CollageID?>" class="brackets" onclick="Unbookmark('collage', <?=$CollageID?>,'Bookmark');return false;">Remove bookmark</a>
|
||||||
<? } else { ?>
|
<? } else { ?>
|
||||||
@ -370,8 +373,8 @@ function compare($X, $Y){
|
|||||||
<div class="pad"><?=$Text->full_format($Description)?></div>
|
<div class="pad"><?=$Text->full_format($Description)?></div>
|
||||||
</div>
|
</div>
|
||||||
<?
|
<?
|
||||||
if(check_perms('zip_downloader')){
|
if (check_perms('zip_downloader')){
|
||||||
if(isset($LoggedUser['Collector'])) {
|
if (isset($LoggedUser['Collector'])) {
|
||||||
list($ZIPList,$ZIPPrefs) = $LoggedUser['Collector'];
|
list($ZIPList,$ZIPPrefs) = $LoggedUser['Collector'];
|
||||||
$ZIPList = explode(':',$ZIPList);
|
$ZIPList = explode(':',$ZIPList);
|
||||||
} else {
|
} else {
|
||||||
@ -404,16 +407,16 @@ function compare($X, $Y){
|
|||||||
foreach ($ZIPOptions as $Option) {
|
foreach ($ZIPOptions as $Option) {
|
||||||
list($GroupID,$OptionID,$OptName) = $Option;
|
list($GroupID,$OptionID,$OptName) = $Option;
|
||||||
|
|
||||||
if($GroupID!=$LastGroupID) {
|
if ($GroupID!=$LastGroupID) {
|
||||||
$LastGroupID=$GroupID;
|
$LastGroupID=$GroupID;
|
||||||
if($OpenGroup) { ?>
|
if ($OpenGroup) { ?>
|
||||||
</optgroup>
|
</optgroup>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<optgroup label="<?=$ZIPGroups[$GroupID]?>">
|
<optgroup label="<?=$ZIPGroups[$GroupID]?>">
|
||||||
<? $OpenGroup = true;
|
<? $OpenGroup = true;
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
<option id="opt<?=$GroupID.$OptionID?>" value="<?=$GroupID.$OptionID?>"<? if(in_array($GroupID.$OptionID,$ZIPList)){ echo ' disabled="disabled"'; }?>><?=$OptName?></option>
|
<option id="opt<?=$GroupID.$OptionID?>" value="<?=$GroupID.$OptionID?>"<? if (in_array($GroupID.$OptionID,$ZIPList)){ echo ' disabled="disabled"'; }?>><?=$OptName?></option>
|
||||||
<?
|
<?
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
@ -421,9 +424,9 @@ function compare($X, $Y){
|
|||||||
</select>
|
</select>
|
||||||
<button type="button" onclick="add_selection()">+</button>
|
<button type="button" onclick="add_selection()">+</button>
|
||||||
<select name="preference" style="width:210px">
|
<select name="preference" style="width:210px">
|
||||||
<option value="0"<? if($ZIPPrefs==0){ echo ' selected="selected"'; } ?>>Prefer Original</option>
|
<option value="0"<? if ($ZIPPrefs == 0){ echo ' selected="selected"'; } ?>>Prefer Original</option>
|
||||||
<option value="1"<? if($ZIPPrefs==1){ echo ' selected="selected"'; } ?>>Prefer Best Seeded</option>
|
<option value="1"<? if ($ZIPPrefs == 1){ echo ' selected="selected"'; } ?>>Prefer Best Seeded</option>
|
||||||
<option value="2"<? if($ZIPPrefs==2){ echo ' selected="selected"'; } ?>>Prefer Bonus Tracks</option>
|
<option value="2"<? if ($ZIPPrefs == 2){ echo ' selected="selected"'; } ?>>Prefer Bonus Tracks</option>
|
||||||
</select>
|
</select>
|
||||||
<input type="submit" style="width:210px" value="Download" />
|
<input type="submit" style="width:210px" value="Download" />
|
||||||
</form>
|
</form>
|
||||||
@ -434,7 +437,7 @@ function compare($X, $Y){
|
|||||||
<div class="head"><strong>Stats</strong></div>
|
<div class="head"><strong>Stats</strong></div>
|
||||||
<ul class="stats nobullet">
|
<ul class="stats nobullet">
|
||||||
<li>Torrents: <?=number_format($NumGroups)?></li>
|
<li>Torrents: <?=number_format($NumGroups)?></li>
|
||||||
<? if(!empty($TopArtists)) { ?>
|
<? if (!empty($TopArtists)) { ?>
|
||||||
<li>Artists: <?=number_format(count($TopArtists))?></li>
|
<li>Artists: <?=number_format(count($TopArtists))?></li>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<li>Built by <?=number_format(count($Users))?> user<?=(count($Users) > 1 ? 's' : '')?></li>
|
<li>Built by <?=number_format(count($Users))?> user<?=(count($Users) > 1 ? 's' : '')?></li>
|
||||||
@ -450,7 +453,7 @@ function compare($X, $Y){
|
|||||||
</ol>
|
</ol>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<? if(!empty($TopArtists)) { ?>
|
<? if (!empty($TopArtists)) { ?>
|
||||||
<div class="box box_artists">
|
<div class="box box_artists">
|
||||||
<div class="head"><strong>Top artists</strong></div>
|
<div class="head"><strong>Top artists</strong></div>
|
||||||
<div class="pad">
|
<div class="pad">
|
||||||
@ -460,7 +463,9 @@ function compare($X, $Y){
|
|||||||
$i = 0;
|
$i = 0;
|
||||||
foreach ($TopArtists as $ID => $Artist) {
|
foreach ($TopArtists as $ID => $Artist) {
|
||||||
$i++;
|
$i++;
|
||||||
if($i>10) { break; }
|
if ($i > 10) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
<li><a href="artist.php?id=<?=$ID?>"><?=$Artist['name']?></a> (<?=number_format($Artist['count'])?>)</li>
|
<li><a href="artist.php?id=<?=$ID?>"><?=$Artist['name']?></a> (<?=number_format($Artist['count'])?>)</li>
|
||||||
<?
|
<?
|
||||||
@ -479,17 +484,18 @@ function compare($X, $Y){
|
|||||||
$i = 0;
|
$i = 0;
|
||||||
foreach ($Users as $ID => $User) {
|
foreach ($Users as $ID => $User) {
|
||||||
$i++;
|
$i++;
|
||||||
if($i>5) { break; }
|
if ($i > 5) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
<li><?=Users::format_username($ID, false, false, false)?> (<?=number_format($User['count'])?>)</li>
|
<li><?=Users::format_username($ID, false, false, false)?> (<?=number_format($User['count'])?>)</li>
|
||||||
<?
|
<?
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
</ol>
|
</ol>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<? if(check_perms('site_collages_manage') && !$PreventAdditions) { ?>
|
<? if (check_perms('site_collages_manage') && !$PreventAdditions) { ?>
|
||||||
<div class="box box_addtorrent">
|
<div class="box box_addtorrent">
|
||||||
<div class="head"><strong>Add torrent</strong><span class="float_right"><a href="#" onclick="$('.add_torrent_container').toggle_class('hidden'); this.innerHTML = (this.innerHTML == 'Batch add'?'Individual add':'Batch add'); return false;" class="brackets">Batch add</a></span></div>
|
<div class="head"><strong>Add torrent</strong><span class="float_right"><a href="#" onclick="$('.add_torrent_container').toggle_class('hidden'); this.innerHTML = (this.innerHTML == 'Batch add'?'Individual add':'Batch add'); return false;" class="brackets">Batch add</a></span></div>
|
||||||
<div class="pad add_torrent_container">
|
<div class="pad add_torrent_container">
|
||||||
@ -518,7 +524,7 @@ function compare($X, $Y){
|
|||||||
<? } ?>
|
<? } ?>
|
||||||
<h3>Comments</h3>
|
<h3>Comments</h3>
|
||||||
<?
|
<?
|
||||||
if(empty($CommentList)) {
|
if (empty($CommentList)) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
cc.ID,
|
cc.ID,
|
||||||
cc.Body,
|
cc.Body,
|
||||||
@ -549,7 +555,7 @@ function compare($X, $Y){
|
|||||||
<a href="collages.php?action=comments&collageid=<?=$CollageID?>" class="brackets">View all comments</a>
|
<a href="collages.php?action=comments&collageid=<?=$CollageID?>" class="brackets">View all comments</a>
|
||||||
</div>
|
</div>
|
||||||
<?
|
<?
|
||||||
if(!$LoggedUser['DisablePosting']) {
|
if (!$LoggedUser['DisablePosting']) {
|
||||||
?>
|
?>
|
||||||
<div class="box box_addcomment">
|
<div class="box box_addcomment">
|
||||||
<div class="head"><strong>Add comment</strong></div>
|
<div class="head"><strong>Add comment</strong></div>
|
||||||
@ -570,13 +576,13 @@ function compare($X, $Y){
|
|||||||
</div>
|
</div>
|
||||||
<div class="main_column">
|
<div class="main_column">
|
||||||
<?
|
<?
|
||||||
if($CollageCovers != 0) { ?>
|
if ($CollageCovers != 0) { ?>
|
||||||
<div id="coverart" class="box">
|
<div id="coverart" class="box">
|
||||||
<div class="head" id="coverhead"><strong>Cover art</strong></div>
|
<div class="head" id="coverhead"><strong>Cover art</strong></div>
|
||||||
<ul class="collage_images" id="collage_page0">
|
<ul class="collage_images" id="collage_page0">
|
||||||
<?
|
<?
|
||||||
$Page1 = array_slice($Collage, 0, $CollageCovers);
|
$Page1 = array_slice($Collage, 0, $CollageCovers);
|
||||||
foreach($Page1 as $Group) {
|
foreach ($Page1 as $Group) {
|
||||||
echo $Group;
|
echo $Group;
|
||||||
}?>
|
}?>
|
||||||
</ul>
|
</ul>
|
||||||
@ -585,12 +591,12 @@ function compare($X, $Y){
|
|||||||
<div class="linkbox pager" style="clear: left;" id="pageslinksdiv">
|
<div class="linkbox pager" style="clear: left;" id="pageslinksdiv">
|
||||||
<span id="firstpage" class="invisible"><a href="#" class="pageslink" onclick="collageShow.page(0, this); return false;"><< First</a> | </span>
|
<span id="firstpage" class="invisible"><a href="#" class="pageslink" onclick="collageShow.page(0, this); return false;"><< First</a> | </span>
|
||||||
<span id="prevpage" class="invisible"><a href="#" class="pageslink" onclick="collageShow.prevPage(); return false;">< Prev</a> | </span>
|
<span id="prevpage" class="invisible"><a href="#" class="pageslink" onclick="collageShow.prevPage(); return false;">< Prev</a> | </span>
|
||||||
<? for ($i=0; $i < $NumGroups/$CollageCovers; $i++) { ?>
|
<? for ($i = 0; $i < $NumGroups / $CollageCovers; $i++) { ?>
|
||||||
<span id="pagelink<?=$i?>" class="<?=(($i>4)?'hidden':'')?><?=(($i==0)?'selected':'')?>"><a href="#" class="pageslink" onclick="collageShow.page(<?=$i?>, this); return false;"><?=$CollageCovers*$i+1?>-<?=min($NumGroups,$CollageCovers*($i+1))?></a><?=($i != ceil($NumGroups/$CollageCovers)-1)?' | ':''?></span>
|
<span id="pagelink<?=$i?>" class="<?=(($i > 4) ? 'hidden' : '')?><?=(($i == 0) ? 'selected' : '')?>"><a href="#" class="pageslink" onclick="collageShow.page(<?=$i?>, this); return false;"><?=$CollageCovers * $i + 1?>-<?=min($NumGroups,$CollageCovers * ($i + 1))?></a><?=($i != ceil($NumGroups / $CollageCovers) - 1) ? ' | ' : ''?></span>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<span id="nextbar" class="<?=($NumGroups/$CollageCovers > 5)?'hidden':''?>"> | </span>
|
<span id="nextbar" class="<?=($NumGroups / $CollageCovers > 5) ? 'hidden' : ''?>"> | </span>
|
||||||
<span id="nextpage"><a href="#" class="pageslink" onclick="collageShow.nextPage(); return false;">Next ></a></span>
|
<span id="nextpage"><a href="#" class="pageslink" onclick="collageShow.nextPage(); return false;">Next ></a></span>
|
||||||
<span id="lastpage" class="<?=ceil($NumGroups/$CollageCovers)==2?'invisible':''?>"> | <a href="#" class="pageslink" onclick="collageShow.page(<?=ceil($NumGroups/$CollageCovers)-1?>, this); return false;">Last >></a></span>
|
<span id="lastpage" class="<?=ceil($NumGroups / $CollageCovers) == 2 ? 'invisible' : ''?>"> | <a href="#" class="pageslink" onclick="collageShow.page(<?=ceil($NumGroups / $CollageCovers) - 1?>, this); return false;">Last >></a></span>
|
||||||
</div>
|
</div>
|
||||||
<script type="text/javascript">//<![CDATA[
|
<script type="text/javascript">//<![CDATA[
|
||||||
collageShow.init(<?=json_encode($CollagePages)?>);
|
collageShow.init(<?=json_encode($CollagePages)?>);
|
||||||
|
@ -43,16 +43,16 @@
|
|||||||
$PermittedForums = array_keys($LoggedUser['PermittedForums']);
|
$PermittedForums = array_keys($LoggedUser['PermittedForums']);
|
||||||
foreach ($Forums as $Forum) {
|
foreach ($Forums as $Forum) {
|
||||||
list($ForumID, $CategoryID, $ForumName, $ForumDescription, $MinRead, $MinWrite, $MinCreate, $NumTopics, $NumPosts, $LastPostID, $LastAuthorID, $LastTopicID, $LastTime, $SpecificRules, $LastTopic, $Locked, $Sticky) = array_values($Forum);
|
list($ForumID, $CategoryID, $ForumName, $ForumDescription, $MinRead, $MinWrite, $MinCreate, $NumTopics, $NumPosts, $LastPostID, $LastAuthorID, $LastTopicID, $LastTime, $SpecificRules, $LastTopic, $Locked, $Sticky) = array_values($Forum);
|
||||||
if ($LoggedUser['CustomForums'][$ForumID] != 1 && ($MinRead>$LoggedUser['Class'] || array_search($ForumID, $RestrictedForums) !== FALSE)) {
|
if ($LoggedUser['CustomForums'][$ForumID] != 1 && ($MinRead > $LoggedUser['Class'] || array_search($ForumID, $RestrictedForums) !== false)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$Row = ($Row == 'a') ? 'b' : 'a';
|
$Row = ($Row == 'a') ? 'b' : 'a';
|
||||||
$ForumDescription = display_str($ForumDescription);
|
$ForumDescription = display_str($ForumDescription);
|
||||||
|
|
||||||
if($CategoryID!=$LastCategoryID) {
|
if ($CategoryID != $LastCategoryID) {
|
||||||
$Row = 'b';
|
$Row = 'b';
|
||||||
$LastCategoryID=$CategoryID;
|
$LastCategoryID = $CategoryID;
|
||||||
if($OpenTable) { ?>
|
if ($OpenTable) { ?>
|
||||||
</table>
|
</table>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<h3><?=$ForumCats[$CategoryID]?></h3>
|
<h3><?=$ForumCats[$CategoryID]?></h3>
|
||||||
@ -68,7 +68,7 @@
|
|||||||
$OpenTable = true;
|
$OpenTable = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((!$Locked || $Sticky) && $LastPostID != 0 && ((empty($LastRead[$LastTopicID]) || $LastRead[$LastTopicID]['PostID'] < $LastPostID) && strtotime($LastTime)>$LoggedUser['CatchupTime'])) {
|
if ((!$Locked || $Sticky) && $LastPostID != 0 && ((empty($LastRead[$LastTopicID]) || $LastRead[$LastTopicID]['PostID'] < $LastPostID) && strtotime($LastTime) > $LoggedUser['CatchupTime'])) {
|
||||||
$Read = 'unread';
|
$Read = 'unread';
|
||||||
} else {
|
} else {
|
||||||
$Read = 'read';
|
$Read = 'read';
|
||||||
@ -87,11 +87,11 @@
|
|||||||
</td>
|
</td>
|
||||||
<? if ($NumPosts == 0) { ?>
|
<? if ($NumPosts == 0) { ?>
|
||||||
<td colspan="3">
|
<td colspan="3">
|
||||||
There are no topics here<?=($MinCreate<=$LoggedUser['Class']) ? ', <a href="forums.php?action=new&forumid='.$ForumID.'">'.'create one'.'</a>' : ''?>.
|
There are no topics here<?=($MinCreate <= $LoggedUser['Class']) ? ', <a href="forums.php?action=new&forumid='.$ForumID.'">'.'create one'.'</a>' : ''?>.
|
||||||
</td>
|
</td>
|
||||||
<? } else { ?>
|
<? } else { ?>
|
||||||
<td>
|
<td>
|
||||||
<span style="float:left;" class="last_topic">
|
<span style="float: left;" class="last_topic">
|
||||||
<a href="forums.php?action=viewthread&threadid=<?=$LastTopicID?>" title="<?=display_str($LastTopic)?>"><?=display_str(Format::cut_string($LastTopic, 50, 1))?></a>
|
<a href="forums.php?action=viewthread&threadid=<?=$LastTopicID?>" title="<?=display_str($LastTopic)?>"><?=display_str(Format::cut_string($LastTopic, 50, 1))?></a>
|
||||||
</span>
|
</span>
|
||||||
<? if (!empty($LastRead[$LastTopicID])) { ?>
|
<? if (!empty($LastRead[$LastTopicID])) { ?>
|
||||||
@ -99,7 +99,7 @@
|
|||||||
<a href="forums.php?action=viewthread&threadid=<?=$LastTopicID?>&page=<?=$LastRead[$LastTopicID]['Page']?>#post<?=$LastRead[$LastTopicID]['PostID']?>"></a>
|
<a href="forums.php?action=viewthread&threadid=<?=$LastTopicID?>&page=<?=$LastRead[$LastTopicID]['Page']?>#post<?=$LastRead[$LastTopicID]['PostID']?>"></a>
|
||||||
</span>
|
</span>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<span style="float:right;" class="last_poster">by <?=Users::format_username($LastAuthorID, false, false, false)?> <?=time_diff($LastTime,1)?></span>
|
<span style="float: right;" class="last_poster">by <?=Users::format_username($LastAuthorID, false, false, false)?> <?=time_diff($LastTime,1)?></span>
|
||||||
</td>
|
</td>
|
||||||
<td><?=number_format($NumTopics)?></td>
|
<td><?=number_format($NumTopics)?></td>
|
||||||
<td><?=number_format($NumPosts)?></td>
|
<td><?=number_format($NumPosts)?></td>
|
||||||
|
@ -99,7 +99,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$Thread = Format::catalogue_select($Catalogue,$Page,$PerPage,THREAD_CATALOGUE);
|
$Thread = Format::catalogue_select($Catalogue,$Page,$PerPage,THREAD_CATALOGUE);
|
||||||
if($_GET['updatelastread'] != '0') {
|
if ($_GET['updatelastread'] != '0') {
|
||||||
$LastPost = end($Thread);
|
$LastPost = end($Thread);
|
||||||
$LastPost = $LastPost['ID'];
|
$LastPost = $LastPost['ID'];
|
||||||
reset($Thread);
|
reset($Thread);
|
||||||
@ -124,17 +124,17 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Handle subscriptions
|
//Handle subscriptions
|
||||||
if(($UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) === FALSE) {
|
if (($UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) === false) {
|
||||||
$DB->query("SELECT TopicID FROM users_subscriptions WHERE UserID = '$LoggedUser[ID]'");
|
$DB->query("SELECT TopicID FROM users_subscriptions WHERE UserID = '$LoggedUser[ID]'");
|
||||||
$UserSubscriptions = $DB->collect(0);
|
$UserSubscriptions = $DB->collect(0);
|
||||||
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(empty($UserSubscriptions)) {
|
if (empty($UserSubscriptions)) {
|
||||||
$UserSubscriptions = array();
|
$UserSubscriptions = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(in_array($ThreadID, $UserSubscriptions)) {
|
if (in_array($ThreadID, $UserSubscriptions)) {
|
||||||
$Cache->delete_value('subscriptions_user_new_'.$LoggedUser['ID']);
|
$Cache->delete_value('subscriptions_user_new_'.$LoggedUser['ID']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
Many forums (Tutorials, The Library, etc.) have their own set of rules. Make sure you read and take note of these rules before you attempt to post in one of these forums.
|
Many forums (Tutorials, The Library, etc.) have their own set of rules. Make sure you read and take note of these rules before you attempt to post in one of these forums.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
Don't use all capital letters, excessive !!! (exclamation marks) or ??? (question marks), it seems like you're shouting!
|
Don't use all capital letters, excessive !!! (exclamation marks) or ??? (question marks). It seems like you're shouting!
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
No lame referral schemes. This includes freeipods.com, freepsps.com, or any other similar scheme in which the poster gets personal gain from users clicking a link.
|
No lame referral schemes. This includes freeipods.com, freepsps.com, or any other similar scheme in which the poster gets personal gain from users clicking a link.
|
||||||
@ -24,22 +24,22 @@
|
|||||||
No asking for money for any reason whatsoever. We don't know or care about your friend who lost everything, or dying relative who wants to enjoy their last few moments alive by being given lots of money.
|
No asking for money for any reason whatsoever. We don't know or care about your friend who lost everything, or dying relative who wants to enjoy their last few moments alive by being given lots of money.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
No advertising your uploads.
|
Do not inappropriately advertise your uploads. In special cases, it is acceptable to mention new uploads in an approved thread (e.g. <a href="forums.php?action=viewthread&threadid=133982">New Users — We'll Snatch Your First 100% FLAC</a>), but be sure to carefully read the thread's rules before posting. It is also acceptable to discuss releases you have uploaded when conversing about the music itself. Blatant attempts to advertise your uploads outside of the appropriate forums or threads may result in a warning or the loss of forum privileges.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
No posting music requests in forums, there's a request link on the top bar, please use that instead.
|
No posting music requests in forums. There's a request link at the top of the page; please use that instead.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
No flaming, be pleasant and polite. Don't use offensive language, and don't be confrontational for the sake of confrontation.
|
No flaming; be pleasant and polite. Don't use offensive language, and don't be confrontational for the sake of confrontation.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
Don't point out or attack other members' share ratios. A higher ratio does not make you better than someone else.
|
Don't point out or attack other members' share ratios. A higher ratio does not make you better than someone else.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
Try not to ask stupid questions. A stupid question is one that you could have found the answer to yourself with a little research, or one that you're asking in the wrong place. If you do the basic research suggested (i.e., read the rules/wiki) or search the forums and don't find the answer to your question, then go ahead and ask. Staff/FLS are not here to hand-feed you the answers you could have found on your own with a little bit of effort.
|
Try not to ask stupid questions. A stupid question is one that you could have found the answer to yourself with a little research, or one that you're asking in the wrong place. If you do the basic research suggested (i.e., read the rules/wiki) or search the forums and don't find the answer to your question, then go ahead and ask. Staff and First Line Support (FLS) are not here to hand-feed you the answers you could have found on your own with a little bit of effort.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
Be sure you read all the stickies.
|
Be sure you read all the sticky threads in a forum before you post.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
Use descriptive and specific subject lines. This helps others decide whether your particular words of wisdom relate to a topic they care about.
|
Use descriptive and specific subject lines. This helps others decide whether your particular words of wisdom relate to a topic they care about.
|
||||||
@ -75,10 +75,10 @@
|
|||||||
Be cautious when posting mature content on the forums. All mature imagery must abide by <a href="wiki.php?action=article&id=1063">the rules found here</a>. Gratuitously sexual or violent content which falls outside of the allowable categories will result in a warning or worse.
|
Be cautious when posting mature content on the forums. All mature imagery must abide by <a href="wiki.php?action=article&id=1063">the rules found here</a>. Gratuitously sexual or violent content which falls outside of the allowable categories will result in a warning or worse.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
Mature content in posts must be properly tagged. The correct format is as follows: <strong>[mature=description] ...content... [/mature]</strong>, where “description” is a mandatory description of the post contents. Misleading or inadequate descriptions will be penalized.
|
Mature content in posts must be properly tagged. The correct format is as follows: <strong>[mature=description] ...content... [/mature]</strong>, where "description" is a mandatory description of the post contents. Misleading or inadequate descriptions will be penalized.
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
Threads created for the exclusive purpose of posting mature imagery will be trashed. Mature content (including graphic album art) should be contextually relevant to the thread and/or forum you’re posting in. Mature content is only allowed in: The Lounge, The Lounge +1, The Library, Music, Power Users, Elite, Torrent Masters, VIPs, Comics, Contests & Designs, The Laboratory. If you are in doubt about a post’s appropriateness, send a <a href="staffpm.php">Staff PM to the Forum Moderators</a> and wait for a reply before proceeding.
|
Threads created for the exclusive purpose of posting mature imagery will be trashed. Mature content (including graphic album art) should be contextually relevant to the thread and/or forum you're posting in. Mature content is only allowed in: The Lounge, The Lounge +1, The Library, Music, Power Users, Elite, Torrent Masters, VIPs, Comics, Contests & Designs, The Laboratory. If you are in doubt about a post's appropriateness, send a <a href="staffpm.php">Staff PM to the Forum Moderators</a> and wait for a reply before proceeding.
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
@ -2,21 +2,21 @@
|
|||||||
function get_fls() {
|
function get_fls() {
|
||||||
global $Cache, $DB;
|
global $Cache, $DB;
|
||||||
static $FLS;
|
static $FLS;
|
||||||
if(is_array($FLS)) {
|
if (is_array($FLS)) {
|
||||||
return $FLS;
|
return $FLS;
|
||||||
}
|
}
|
||||||
if(($FLS = $Cache->get_value('fls')) === false) {
|
if (($FLS = $Cache->get_value('fls')) === false) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
m.ID,
|
m.ID,
|
||||||
p.Level,
|
p.Level,
|
||||||
m.Username,
|
m.Username,
|
||||||
m.Paranoia,
|
m.Paranoia,
|
||||||
m.LastAccess,
|
m.LastAccess,
|
||||||
i.SupportFor
|
i.SupportFor
|
||||||
FROM users_info AS i
|
FROM users_info AS i
|
||||||
JOIN users_main AS m ON m.ID=i.UserID
|
JOIN users_main AS m ON m.ID=i.UserID
|
||||||
JOIN permissions AS p ON p.ID=m.PermissionID
|
JOIN permissions AS p ON p.ID=m.PermissionID
|
||||||
JOIN users_levels AS l ON l.UserID = i.UserID
|
JOIN users_levels AS l ON l.UserID = i.UserID
|
||||||
WHERE l.PermissionID = ".FLS_TEAM);
|
WHERE l.PermissionID = ".FLS_TEAM);
|
||||||
$FLS = $DB->to_array(false, MYSQLI_BOTH, array(3,'Paranoia'));
|
$FLS = $DB->to_array(false, MYSQLI_BOTH, array(3,'Paranoia'));
|
||||||
$Cache->cache_value('fls', $FLS, 180);
|
$Cache->cache_value('fls', $FLS, 180);
|
||||||
@ -27,20 +27,20 @@ function get_fls() {
|
|||||||
function get_forum_staff() {
|
function get_forum_staff() {
|
||||||
global $Cache, $DB;
|
global $Cache, $DB;
|
||||||
static $ForumStaff;
|
static $ForumStaff;
|
||||||
if(is_array($ForumStaff)) {
|
if (is_array($ForumStaff)) {
|
||||||
return $ForumStaff;
|
return $ForumStaff;
|
||||||
}
|
}
|
||||||
if(($ForumStaff = $Cache->get_value('forum_staff')) === false) {
|
if (($ForumStaff = $Cache->get_value('forum_staff')) === false) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
m.ID,
|
m.ID,
|
||||||
p.Level,
|
p.Level,
|
||||||
m.Username,
|
m.Username,
|
||||||
m.Paranoia,
|
m.Paranoia,
|
||||||
m.LastAccess,
|
m.LastAccess,
|
||||||
i.SupportFor
|
i.SupportFor
|
||||||
FROM users_main AS m
|
FROM users_main AS m
|
||||||
JOIN users_info AS i ON m.ID=i.UserID
|
JOIN users_info AS i ON m.ID=i.UserID
|
||||||
JOIN permissions AS p ON p.ID=m.PermissionID
|
JOIN permissions AS p ON p.ID=m.PermissionID
|
||||||
WHERE p.DisplayStaff='1'
|
WHERE p.DisplayStaff='1'
|
||||||
AND p.Level < 700
|
AND p.Level < 700
|
||||||
ORDER BY p.Level, m.LastAccess ASC");
|
ORDER BY p.Level, m.LastAccess ASC");
|
||||||
@ -53,21 +53,21 @@ function get_forum_staff() {
|
|||||||
function get_staff() {
|
function get_staff() {
|
||||||
global $Cache, $DB;
|
global $Cache, $DB;
|
||||||
static $Staff;
|
static $Staff;
|
||||||
if(is_array($Staff)) {
|
if (is_array($Staff)) {
|
||||||
return $Staff;
|
return $Staff;
|
||||||
}
|
}
|
||||||
if(($Staff = $Cache->get_value('staff')) === false) {
|
if (($Staff = $Cache->get_value('staff')) === false) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
m.ID,
|
m.ID,
|
||||||
p.Level,
|
p.Level,
|
||||||
p.Name,
|
p.Name,
|
||||||
m.Username,
|
m.Username,
|
||||||
m.Paranoia,
|
m.Paranoia,
|
||||||
m.LastAccess,
|
m.LastAccess,
|
||||||
i.SupportFor
|
i.SupportFor
|
||||||
FROM users_main AS m
|
FROM users_main AS m
|
||||||
JOIN users_info AS i ON m.ID=i.UserID
|
JOIN users_info AS i ON m.ID=i.UserID
|
||||||
JOIN permissions AS p ON p.ID=m.PermissionID
|
JOIN permissions AS p ON p.ID=m.PermissionID
|
||||||
WHERE p.DisplayStaff='1'
|
WHERE p.DisplayStaff='1'
|
||||||
AND p.Level >= 700
|
AND p.Level >= 700
|
||||||
ORDER BY p.Level, m.LastAccess ASC");
|
ORDER BY p.Level, m.LastAccess ASC");
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
<div class="header">
|
<div class="header">
|
||||||
<h2><?=SITE_NAME?> Staff</h2>
|
<h2><?=SITE_NAME?> Staff</h2>
|
||||||
</div>
|
</div>
|
||||||
<div class="box pad" style="padding:0px 10px 10px 10px;">
|
<div class="box pad" style="padding: 0px 10px 10px 10px;">
|
||||||
<br />
|
<br />
|
||||||
<h3>Contact Staff</h3>
|
<h3>Contact Staff</h3>
|
||||||
<div id="below_box">
|
<div id="below_box">
|
||||||
@ -26,22 +26,27 @@
|
|||||||
<p><strong>These users are not official staff members</strong> - they're users who have volunteered their time to help people in need. Please treat them with respect and read <a href="wiki.php?action=article&id=260">this</a> before contacting them.</p>
|
<p><strong>These users are not official staff members</strong> - they're users who have volunteered their time to help people in need. Please treat them with respect and read <a href="wiki.php?action=article&id=260">this</a> before contacting them.</p>
|
||||||
<table class="staff" width="100%">
|
<table class="staff" width="100%">
|
||||||
<tr class="colhead">
|
<tr class="colhead">
|
||||||
<td style="width:130px;">Username</td>
|
<td style="width: 130px;">Username</td>
|
||||||
<td style="width:130px;">Last seen</td>
|
<td style="width: 130px;">Last seen</td>
|
||||||
<td><strong>Support for</strong></td>
|
<td><strong>Support for</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
<?
|
<?
|
||||||
$Row = 'a';
|
$Row = 'a';
|
||||||
foreach($FrontLineSupport as $Support) {
|
foreach ($FrontLineSupport as $Support) {
|
||||||
list($ID, $Class, $Username, $Paranoia, $LastAccess, $SupportFor) = $Support;
|
list($ID, $Class, $Username, $Paranoia, $LastAccess, $SupportFor) = $Support;
|
||||||
$Row = ($Row == 'a') ? 'b' : 'a';
|
$Row = ($Row == 'a') ? 'b' : 'a';
|
||||||
?>
|
?>
|
||||||
<tr class="row<?=$Row?>">
|
<tr class="row<?=$Row?>">
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<?=Users::format_username($ID, false, false, false)?>
|
<?=Users::format_username($ID, false, false, false) ?>
|
||||||
</td>
|
</td>
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<? if (check_paranoia('lastseen', $Paranoia, $Class)) { echo time_diff($LastAccess); } else { echo 'Hidden by user'; }?>
|
<? if (check_paranoia('lastseen', $Paranoia, $Class)) {
|
||||||
|
echo time_diff($LastAccess);
|
||||||
|
} else {
|
||||||
|
echo 'Hidden by user';
|
||||||
|
}
|
||||||
|
?>
|
||||||
</td>
|
</td>
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<?=$SupportFor?>
|
<?=$SupportFor?>
|
||||||
@ -50,28 +55,33 @@
|
|||||||
<? } ?>
|
<? } ?>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<div class="box pad" style="padding:0px 10px 10px 10px;">
|
<div class="box pad" style="padding: 0px 10px 10px 10px;">
|
||||||
<br />
|
<br />
|
||||||
<h3>Forum Moderators</h3>
|
<h3>Forum Moderators</h3>
|
||||||
<p>Forum Moderators are users who have been promoted to help moderate the forums. They can only help with forum-oriented questions.</p>
|
<p>Forum Moderators are users who have been promoted to help moderate the forums. They can only help with forum-oriented questions.</p>
|
||||||
<table class="staff" width="100%">
|
<table class="staff" width="100%">
|
||||||
<tr class="colhead">
|
<tr class="colhead">
|
||||||
<td style="width:130px;">Username</td>
|
<td style="width: 130px;">Username</td>
|
||||||
<td style="width:130px;">Last seen</td>
|
<td style="width: 130px;">Last seen</td>
|
||||||
<td><strong>Remark</strong></td>
|
<td><strong>Remark</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
<?
|
<?
|
||||||
$Row = 'a';
|
$Row = 'a';
|
||||||
foreach($ForumStaff as $Support) {
|
foreach ($ForumStaff as $Support) {
|
||||||
list($ID, $Class, $Username, $Paranoia, $LastAccess, $SupportFor) = $Support;
|
list($ID, $Class, $Username, $Paranoia, $LastAccess, $SupportFor) = $Support;
|
||||||
$Row = ($Row == 'a') ? 'b' : 'a';
|
$Row = ($Row == 'a') ? 'b' : 'a';
|
||||||
?>
|
?>
|
||||||
<tr class="row<?=$Row?>">
|
<tr class="row<?=$Row?>">
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<?=Users::format_username($ID, false, false, false)?>
|
<?=Users::format_username($ID, false, false, false) ?>
|
||||||
</td>
|
</td>
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<? if (check_paranoia('lastseen', $Paranoia, $Class)) { echo time_diff($LastAccess); } else { echo 'Hidden by user'; }?>
|
<? if (check_paranoia('lastseen', $Paranoia, $Class)) {
|
||||||
|
echo time_diff($LastAccess);
|
||||||
|
} else {
|
||||||
|
echo 'Hidden by user';
|
||||||
|
}
|
||||||
|
?>
|
||||||
</td>
|
</td>
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<?=$SupportFor?>
|
<?=$SupportFor?>
|
||||||
@ -81,15 +91,15 @@
|
|||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<br />
|
<br />
|
||||||
<div class="box pad" style="padding:0px 10px 10px 10px;">
|
<div class="box pad" style="padding: 0px 10px 10px 10px;">
|
||||||
<?
|
<?
|
||||||
$CurClass = 0;
|
$CurClass = 0;
|
||||||
$CloseTable = false;
|
$CloseTable = false;
|
||||||
foreach ($Staff as $StaffMember) {
|
foreach ($Staff as $StaffMember) {
|
||||||
list($ID, $Class, $ClassName, $Username, $Paranoia, $LastAccess, $Remark) = $StaffMember;
|
list($ID, $Class, $ClassName, $Username, $Paranoia, $LastAccess, $Remark) = $StaffMember;
|
||||||
if($Class!=$CurClass) { // Start new class of staff members
|
if ($Class != $CurClass) { // Start new class of staff members
|
||||||
$Row = 'a';
|
$Row = 'a';
|
||||||
if($CloseTable) {
|
if ($CloseTable) {
|
||||||
$CloseTable = false;
|
$CloseTable = false;
|
||||||
echo "\t</table><br />";
|
echo "\t</table><br />";
|
||||||
}
|
}
|
||||||
@ -99,8 +109,8 @@
|
|||||||
?>
|
?>
|
||||||
<table class="staff" width="100%">
|
<table class="staff" width="100%">
|
||||||
<tr class="colhead">
|
<tr class="colhead">
|
||||||
<td style="width:130px;">Username</td>
|
<td style="width: 130px;">Username</td>
|
||||||
<td style="width:130px;">Last seen</td>
|
<td style="width: 130px;">Last seen</td>
|
||||||
<td><strong>Remark</strong></td>
|
<td><strong>Remark</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
<?
|
<?
|
||||||
@ -111,10 +121,15 @@
|
|||||||
?>
|
?>
|
||||||
<tr class="row<?=$Row?>">
|
<tr class="row<?=$Row?>">
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<?=Users::format_username($ID, false, false, false)?>
|
<?=Users::format_username($ID, false, false, false) ?>
|
||||||
</td>
|
</td>
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<? if (check_paranoia('lastseen', $Paranoia, $Class)) { echo time_diff($LastAccess); } else { echo 'Hidden by staff member'; }?>
|
<? if (check_paranoia('lastseen', $Paranoia, $Class)) {
|
||||||
|
echo time_diff($LastAccess);
|
||||||
|
} else {
|
||||||
|
echo 'Hidden by staff member';
|
||||||
|
}
|
||||||
|
?>
|
||||||
</td>
|
</td>
|
||||||
<td class="nobr">
|
<td class="nobr">
|
||||||
<?=$Remark?>
|
<?=$Remark?>
|
||||||
|
@ -9,20 +9,20 @@
|
|||||||
|
|
||||||
*****************************************************************/
|
*****************************************************************/
|
||||||
|
|
||||||
if(isset($argv[1])) {
|
if (isset($argv[1])) {
|
||||||
if($argv[1] == "cli_sandbox") {
|
if ($argv[1] == "cli_sandbox") {
|
||||||
include("misc/cli_sandbox.php");
|
include("misc/cli_sandbox.php");
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
$_REQUEST['action'] = $argv[1];
|
$_REQUEST['action'] = $argv[1];
|
||||||
} else {
|
} else {
|
||||||
if(empty($_REQUEST['action']) || ($_REQUEST['action'] != "public_sandbox" && $_REQUEST['action'] != "ocelot")) {
|
if (empty($_REQUEST['action']) || ($_REQUEST['action'] != "public_sandbox" && $_REQUEST['action'] != "ocelot")) {
|
||||||
enforce_login();
|
enforce_login();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!isset($_REQUEST['action'])) {
|
if (!isset($_REQUEST['action'])) {
|
||||||
include(SERVER_ROOT.'/sections/tools/tools.php');
|
include(SERVER_ROOT.'/sections/tools/tools.php');
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
@ -120,8 +120,10 @@
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'takeeditnews':
|
case 'takeeditnews':
|
||||||
if(!check_perms('admin_manage_news')){ error(403); }
|
if (!check_perms('admin_manage_news')) {
|
||||||
if(is_number($_POST['newsid'])){
|
error(403);
|
||||||
|
}
|
||||||
|
if (is_number($_POST['newsid'])){
|
||||||
$DB->query("UPDATE news SET Title='".db_string($_POST['title'])."', Body='".db_string($_POST['body'])."' WHERE ID='".db_string($_POST['newsid'])."'");
|
$DB->query("UPDATE news SET Title='".db_string($_POST['title'])."', Body='".db_string($_POST['body'])."' WHERE ID='".db_string($_POST['newsid'])."'");
|
||||||
$Cache->delete_value('news');
|
$Cache->delete_value('news');
|
||||||
$Cache->delete_value('feed_news');
|
$Cache->delete_value('feed_news');
|
||||||
@ -130,8 +132,10 @@
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'deletenews':
|
case 'deletenews':
|
||||||
if(!check_perms('admin_manage_news')){ error(403); }
|
if (!check_perms('admin_manage_news')) {
|
||||||
if(is_number($_GET['id'])){
|
error(403);
|
||||||
|
}
|
||||||
|
if (is_number($_GET['id'])){
|
||||||
authorize();
|
authorize();
|
||||||
$DB->query("DELETE FROM news WHERE ID='".db_string($_GET['id'])."'");
|
$DB->query("DELETE FROM news WHERE ID='".db_string($_GET['id'])."'");
|
||||||
$Cache->delete_value('news');
|
$Cache->delete_value('news');
|
||||||
@ -139,7 +143,7 @@
|
|||||||
|
|
||||||
// Deleting latest news
|
// Deleting latest news
|
||||||
$LatestNews = $Cache->get_value('news_latest_id');
|
$LatestNews = $Cache->get_value('news_latest_id');
|
||||||
if ($LatestNews !== FALSE && $LatestNews == $_GET['id']) {
|
if ($LatestNews !== false && $LatestNews == $_GET['id']) {
|
||||||
$Cache->delete_value('news_latest_id');
|
$Cache->delete_value('news_latest_id');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -147,7 +151,9 @@
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'takenewnews':
|
case 'takenewnews':
|
||||||
if(!check_perms('admin_manage_news')){ error(403); }
|
if (!check_perms('admin_manage_news')) {
|
||||||
|
error(403);
|
||||||
|
}
|
||||||
|
|
||||||
$DB->query("INSERT INTO news (UserID, Title, Body, Time) VALUES ('$LoggedUser[ID]', '".db_string($_POST['title'])."', '".db_string($_POST['body'])."', '".sqltime()."')");
|
$DB->query("INSERT INTO news (UserID, Title, Body, Time) VALUES ('$LoggedUser[ID]', '".db_string($_POST['title'])."', '".db_string($_POST['body'])."', '".sqltime()."')");
|
||||||
|
|
||||||
@ -173,7 +179,9 @@
|
|||||||
include('managers/tag_aliases.php');
|
include('managers/tag_aliases.php');
|
||||||
break;
|
break;
|
||||||
case 'permissions':
|
case 'permissions':
|
||||||
if (!check_perms('admin_manage_permissions')) { error(403); }
|
if (!check_perms('admin_manage_permissions')) {
|
||||||
|
error(403);
|
||||||
|
}
|
||||||
|
|
||||||
if (!empty($_REQUEST['id'])) {
|
if (!empty($_REQUEST['id'])) {
|
||||||
$Val->SetFields('name',true,'string','You did not enter a valid name for this permission set.');
|
$Val->SetFields('name',true,'string','You did not enter a valid name for this permission set.');
|
||||||
@ -185,7 +193,7 @@
|
|||||||
$DB->query("SELECT p.ID,p.Name,p.Level,p.Secondary,p.PermittedForums,p.Values,p.DisplayStaff,COUNT(u.ID) FROM permissions AS p LEFT JOIN users_main AS u ON u.PermissionID=p.ID WHERE p.ID='".db_string($_REQUEST['id'])."' GROUP BY p.ID");
|
$DB->query("SELECT p.ID,p.Name,p.Level,p.Secondary,p.PermittedForums,p.Values,p.DisplayStaff,COUNT(u.ID) FROM permissions AS p LEFT JOIN users_main AS u ON u.PermissionID=p.ID WHERE p.ID='".db_string($_REQUEST['id'])."' GROUP BY p.ID");
|
||||||
list($ID,$Name,$Level,$Secondary,$Forums,$Values,$DisplayStaff,$UserCount)=$DB->next_record(MYSQLI_NUM, array(5));
|
list($ID,$Name,$Level,$Secondary,$Forums,$Values,$DisplayStaff,$UserCount)=$DB->next_record(MYSQLI_NUM, array(5));
|
||||||
|
|
||||||
if($Level > $LoggedUser['EffectiveClass'] || $_REQUEST['level'] > $LoggedUser['EffectiveClass']) {
|
if ($Level > $LoggedUser['EffectiveClass'] || $_REQUEST['level'] > $LoggedUser['EffectiveClass']) {
|
||||||
error(403);
|
error(403);
|
||||||
}
|
}
|
||||||
$Values = unserialize($Values);
|
$Values = unserialize($Values);
|
||||||
@ -205,15 +213,17 @@
|
|||||||
|
|
||||||
$Values=array();
|
$Values=array();
|
||||||
foreach ($_REQUEST as $Key => $Perms) {
|
foreach ($_REQUEST as $Key => $Perms) {
|
||||||
if (substr($Key,0,5)=="perm_") { $Values[substr($Key,5)]= (int)$Perms; }
|
if (substr($Key,0,5) == 'perm_') {
|
||||||
|
$Values[substr($Key,5)] = (int)$Perms;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$Name=$_REQUEST['name'];
|
$Name = $_REQUEST['name'];
|
||||||
$Level=$_REQUEST['level'];
|
$Level = $_REQUEST['level'];
|
||||||
$Secondary=empty($_REQUEST['secondary'])?0:1;
|
$Secondary = empty($_REQUEST['secondary']) ? 0 : 1;
|
||||||
$Forums = $_REQUEST['forums'];
|
$Forums = $_REQUEST['forums'];
|
||||||
$DisplayStaff=$_REQUEST['displaystaff'];
|
$DisplayStaff = $_REQUEST['displaystaff'];
|
||||||
$Values['MaxCollages']=$_REQUEST['maxcollages'];
|
$Values['MaxCollages'] = $_REQUEST['maxcollages'];
|
||||||
|
|
||||||
if (!$Err) {
|
if (!$Err) {
|
||||||
if (!is_numeric($_REQUEST['id'])) {
|
if (!is_numeric($_REQUEST['id'])) {
|
||||||
@ -395,7 +405,7 @@
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'mod_sandbox':
|
case 'mod_sandbox':
|
||||||
if(check_perms('users_mod')) {
|
if (check_perms('users_mod')) {
|
||||||
include('misc/mod_sandbox.php');
|
include('misc/mod_sandbox.php');
|
||||||
} else {
|
} else {
|
||||||
error(403);
|
error(403);
|
||||||
|
@ -77,8 +77,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<? if (check_perms('users_mod')) { ?>
|
<? if (check_perms('users_mod')) { ?>
|
||||||
<td>
|
<td>
|
||||||
<input type="submit" name="save" value="Save Alias" />
|
<input type="submit" name="save" value="Save alias" />
|
||||||
<input type="submit" name="delete" value="Delete Alias" />
|
<input type="submit" name="delete" value="Delete alias" />
|
||||||
</td>
|
</td>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</form>
|
</form>
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
$AuthKey = $LoggedUser['AuthKey'];
|
$AuthKey = $LoggedUser['AuthKey'];
|
||||||
} else {
|
} else {
|
||||||
$UserInfo = $Cache->get_value('user_'.$_REQUEST['torrent_pass']);
|
$UserInfo = $Cache->get_value('user_'.$_REQUEST['torrent_pass']);
|
||||||
if(!is_array($UserInfo)) {
|
if (!is_array($UserInfo)) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
ID,
|
ID,
|
||||||
DownloadAlt
|
DownloadAlt
|
||||||
@ -38,7 +38,7 @@
|
|||||||
/* uTorrent remote redownloads .torrent files every fifteen minutes
|
/* uTorrent remote redownloads .torrent files every fifteen minutes
|
||||||
to prevent this retardation from blowing bandwidth etc., let's block it
|
to prevent this retardation from blowing bandwidth etc., let's block it
|
||||||
if he's downloaded the .torrent file twice before */
|
if he's downloaded the .torrent file twice before */
|
||||||
if (strpos($_SERVER['HTTP_USER_AGENT'], 'BTWebClient') !== FALSE) {
|
if (strpos($_SERVER['HTTP_USER_AGENT'], 'BTWebClient') !== false) {
|
||||||
$DB->query("SELECT 1 FROM users_downloads WHERE UserID=$UserID AND TorrentID=$TorrentID LIMIT 3");
|
$DB->query("SELECT 1 FROM users_downloads WHERE UserID=$UserID AND TorrentID=$TorrentID LIMIT 3");
|
||||||
if ($DB->record_count() > 2) {
|
if ($DB->record_count() > 2) {
|
||||||
error('You have already downloaded this .torrent three times. If you need to download it again, please do so from your browser, not through uTorrent remote.');
|
error('You have already downloaded this .torrent three times. If you need to download it again, please do so from your browser, not through uTorrent remote.');
|
||||||
@ -47,7 +47,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
$Info = $Cache->get_value('torrent_download_'.$TorrentID);
|
$Info = $Cache->get_value('torrent_download_'.$TorrentID);
|
||||||
if(!is_array($Info) || !array_key_exists('PlainArtists', $Info) || empty($Info[10])) {
|
if (!is_array($Info) || !array_key_exists('PlainArtists', $Info) || empty($Info[10])) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
t.Media,
|
t.Media,
|
||||||
t.Format,
|
t.Format,
|
||||||
@ -63,7 +63,7 @@
|
|||||||
FROM torrents AS t
|
FROM torrents AS t
|
||||||
INNER JOIN torrents_group AS tg ON tg.ID=t.GroupID
|
INNER JOIN torrents_group AS tg ON tg.ID=t.GroupID
|
||||||
WHERE t.ID='".db_string($TorrentID)."'");
|
WHERE t.ID='".db_string($TorrentID)."'");
|
||||||
if($DB->record_count() < 1) {
|
if ($DB->record_count() < 1) {
|
||||||
error(404);
|
error(404);
|
||||||
}
|
}
|
||||||
$Info = array($DB->next_record(MYSQLI_NUM, array(4,5,6,10)));
|
$Info = array($DB->next_record(MYSQLI_NUM, array(4,5,6,10)));
|
||||||
@ -72,7 +72,7 @@
|
|||||||
$Info['PlainArtists'] = Artists::display_artists($Artists, false, true, false);
|
$Info['PlainArtists'] = Artists::display_artists($Artists, false, true, false);
|
||||||
$Cache->cache_value('torrent_download_'.$TorrentID, $Info, 0);
|
$Cache->cache_value('torrent_download_'.$TorrentID, $Info, 0);
|
||||||
}
|
}
|
||||||
if(!is_array($Info[0])) {
|
if (!is_array($Info[0])) {
|
||||||
error(404);
|
error(404);
|
||||||
}
|
}
|
||||||
list($Media,$Format,$Encoding,$Year,$GroupID,$Name,$Image, $CategoryID, $Size, $FreeTorrent, $InfoHash) = array_shift($Info); // used for generating the filename
|
list($Media,$Format,$Encoding,$Year,$GroupID,$Name,$Image, $CategoryID, $Size, $FreeTorrent, $InfoHash) = array_shift($Info); // used for generating the filename
|
||||||
@ -129,16 +129,16 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Stupid Recent Snatches On User Page
|
//Stupid Recent Snatches On User Page
|
||||||
if($CategoryID == '1' && $Image != "") {
|
if ($CategoryID == '1' && $Image != "") {
|
||||||
$RecentSnatches = $Cache->get_value('recent_snatches_'.$UserID);
|
$RecentSnatches = $Cache->get_value('recent_snatches_'.$UserID);
|
||||||
if(!empty($RecentSnatches)) {
|
if (!empty($RecentSnatches)) {
|
||||||
$Snatch = array('ID'=>$GroupID,'Name'=>$Name,'Artist'=>$Artists,'WikiImage'=>$Image);
|
$Snatch = array('ID'=>$GroupID,'Name'=>$Name,'Artist'=>$Artists,'WikiImage'=>$Image);
|
||||||
if(!in_array($Snatch, $RecentSnatches)) {
|
if (!in_array($Snatch, $RecentSnatches)) {
|
||||||
if(count($RecentSnatches) == 5) {
|
if (count($RecentSnatches) == 5) {
|
||||||
array_pop($RecentSnatches);
|
array_pop($RecentSnatches);
|
||||||
}
|
}
|
||||||
array_unshift($RecentSnatches, $Snatch);
|
array_unshift($RecentSnatches, $Snatch);
|
||||||
} elseif(!is_array($RecentSnatches)) {
|
} elseif (!is_array($RecentSnatches)) {
|
||||||
$RecentSnatches = array($Snatch);
|
$RecentSnatches = array($Snatch);
|
||||||
}
|
}
|
||||||
$Cache->cache_value('recent_snatches_'.$UserID, $RecentSnatches, 0);
|
$Cache->cache_value('recent_snatches_'.$UserID, $RecentSnatches, 0);
|
||||||
@ -155,7 +155,7 @@
|
|||||||
|
|
||||||
if ($DownloadAlt) {
|
if ($DownloadAlt) {
|
||||||
header('Content-Type: text/plain; charset=utf-8');
|
header('Content-Type: text/plain; charset=utf-8');
|
||||||
} else if (!$DownloadAlt || $Failed) {
|
} elseif (!$DownloadAlt || $Failed) {
|
||||||
header('Content-Type: application/x-bittorrent; charset=utf-8');
|
header('Content-Type: application/x-bittorrent; charset=utf-8');
|
||||||
}
|
}
|
||||||
header('Content-disposition: attachment; filename="'.$FileName.'"');
|
header('Content-disposition: attachment; filename="'.$FileName.'"');
|
||||||
|
@ -149,7 +149,7 @@ function get_group_info($GroupID, $Return = true, $RevisionID = 0, $PersonalProp
|
|||||||
function is_valid_torrenthash($Str) {
|
function is_valid_torrenthash($Str) {
|
||||||
//6C19FF4C 6C1DD265 3B25832C 0F6228B2 52D743D5
|
//6C19FF4C 6C1DD265 3B25832C 0F6228B2 52D743D5
|
||||||
$Str = str_replace(' ', '', $Str);
|
$Str = str_replace(' ', '', $Str);
|
||||||
if(preg_match('/^[0-9a-fA-F]{40}$/', $Str))
|
if (preg_match('/^[0-9a-fA-F]{40}$/', $Str))
|
||||||
return $Str;
|
return $Str;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -168,7 +168,7 @@ function get_group_requests($GroupID) {
|
|||||||
global $DB, $Cache;
|
global $DB, $Cache;
|
||||||
|
|
||||||
$Requests = $Cache->get_value('requests_group_'.$GroupID);
|
$Requests = $Cache->get_value('requests_group_'.$GroupID);
|
||||||
if ($Requests === FALSE) {
|
if ($Requests === false) {
|
||||||
$DB->query("SELECT ID FROM requests WHERE GroupID = $GroupID AND TimeFilled = '0000-00-00 00:00:00'");
|
$DB->query("SELECT ID FROM requests WHERE GroupID = $GroupID AND TimeFilled = '0000-00-00 00:00:00'");
|
||||||
$Requests = $DB->collect('ID');
|
$Requests = $DB->collect('ID');
|
||||||
$Cache->cache_value('requests_group_'.$GroupID, $Requests, 0);
|
$Cache->cache_value('requests_group_'.$GroupID, $Requests, 0);
|
||||||
|
@ -85,7 +85,7 @@
|
|||||||
$Cache->delete_value('vote_pairs_'.$CacheGroupID);
|
$Cache->delete_value('vote_pairs_'.$CacheGroupID);
|
||||||
}
|
}
|
||||||
// 4. Clear the new groups vote keys
|
// 4. Clear the new groups vote keys
|
||||||
|
$Cache->delete_value('votes_'.$NewGroupID);
|
||||||
|
|
||||||
$DB->query("UPDATE torrents SET GroupID='$NewGroupID' WHERE GroupID='$GroupID'");
|
$DB->query("UPDATE torrents SET GroupID='$NewGroupID' WHERE GroupID='$GroupID'");
|
||||||
$DB->query("UPDATE wiki_torrents SET PageID='$NewGroupID' WHERE PageID='$GroupID'");
|
$DB->query("UPDATE wiki_torrents SET PageID='$NewGroupID' WHERE PageID='$GroupID'");
|
||||||
|
@ -76,7 +76,7 @@ function unlink_user($UserID) {
|
|||||||
error(403);
|
error(403);
|
||||||
}
|
}
|
||||||
$UserInfo = Users::user_info($UserID);
|
$UserInfo = Users::user_info($UserID);
|
||||||
if ($UserInfo === FALSE) {
|
if ($UserInfo === false) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$AdminComment = sqltime()." - Linked accounts updated: [user]".$UserInfo['Username']."[/user] unlinked by ".$LoggedUser['Username'];
|
$AdminComment = sqltime()." - Linked accounts updated: [user]".$UserInfo['Username']."[/user] unlinked by ".$LoggedUser['Username'];
|
||||||
@ -167,7 +167,7 @@ function user_dupes_table($UserID) {
|
|||||||
<input type="hidden" id="auth" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
<input type="hidden" id="auth" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
||||||
<input type="hidden" id="form_comment_hash" name="form_comment_hash" value="<?=$CommentHash?>" />
|
<input type="hidden" id="form_comment_hash" name="form_comment_hash" value="<?=$CommentHash?>" />
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<div class="head"><?=max($DupeCount - 1, 0)?> linked account<?=(($DupeCount == 2)?'':'s')?> <a href="#" onclick="$('.linkedaccounts').toggle(); return false;" class="brackets">View</a></div>
|
<div class="head"><?=max($DupeCount - 1, 0)?> Linked account<?=(($DupeCount == 2)?'':'s')?> <a href="#" onclick="$('.linkedaccounts').toggle(); return false;" class="brackets">View</a></div>
|
||||||
<table width="100%" class="layout hidden linkedaccounts">
|
<table width="100%" class="layout hidden linkedaccounts">
|
||||||
<?=$DupeCount?'<tr>':''?>
|
<?=$DupeCount?'<tr>':''?>
|
||||||
<?
|
<?
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
<?
|
<?
|
||||||
if(!check_perms('site_torrents_notify')){ error(403); }
|
if (!check_perms('site_torrents_notify')) {
|
||||||
|
error(403);
|
||||||
|
}
|
||||||
View::show_header('Manage notifications');
|
View::show_header('Manage notifications');
|
||||||
?>
|
?>
|
||||||
<div class="thin">
|
<div class="thin">
|
||||||
@ -16,7 +18,7 @@
|
|||||||
|
|
||||||
$Notifications = $DB->to_array();
|
$Notifications = $DB->to_array();
|
||||||
|
|
||||||
foreach($Notifications as $N) { //$N stands for Notifications
|
foreach ($Notifications as $N) { //$N stands for Notifications
|
||||||
$N['Artists'] = implode(', ', explode('|', substr($N['Artists'],1,-1)));
|
$N['Artists'] = implode(', ', explode('|', substr($N['Artists'],1,-1)));
|
||||||
$N['Tags'] = implode(', ', explode('|', substr($N['Tags'],1,-1)));
|
$N['Tags'] = implode(', ', explode('|', substr($N['Tags'],1,-1)));
|
||||||
$N['NotTags'] = implode(', ', explode('|', substr($N['NotTags'],1,-1)));
|
$N['NotTags'] = implode(', ', explode('|', substr($N['NotTags'],1,-1)));
|
||||||
@ -25,13 +27,13 @@
|
|||||||
$N['Formats'] = explode('|', substr($N['Formats'],1,-1));
|
$N['Formats'] = explode('|', substr($N['Formats'],1,-1));
|
||||||
$N['Encodings'] = explode('|', substr($N['Encodings'],1,-1));
|
$N['Encodings'] = explode('|', substr($N['Encodings'],1,-1));
|
||||||
$N['Media'] = explode('|', substr($N['Media'],1,-1));
|
$N['Media'] = explode('|', substr($N['Media'],1,-1));
|
||||||
if($N['FromYear'] ==0) { $N['FromYear'] = ''; }
|
if ($N['FromYear'] == 0) { $N['FromYear'] = ''; }
|
||||||
if($N['ToYear'] ==0) { $N['ToYear'] = ''; }
|
if ($N['ToYear'] == 0) { $N['ToYear'] = ''; }
|
||||||
$i++;
|
$i++;
|
||||||
|
|
||||||
if($i>$NumFilters && $NumFilters>0){ ?>
|
if ($i > $NumFilters && $NumFilters > 0) { ?>
|
||||||
<h3>Create a new notification filter</h3>
|
<h3>Create a new notification filter</h3>
|
||||||
<? } elseif($NumFilters>0) { ?>
|
<? } elseif ($NumFilters>0) { ?>
|
||||||
<h3>
|
<h3>
|
||||||
<a href="feeds.php?feed=torrents_notify_<?=$N['ID']?>_<?=$LoggedUser['torrent_pass']?>&user=<?=$LoggedUser['ID']?>&auth=<?=$LoggedUser['RSS_Auth']?>&passkey=<?=$LoggedUser['torrent_pass']?>&authkey=<?=$LoggedUser['AuthKey']?>&name=<?=urlencode($N['Label'])?>"><img src="<?=STATIC_SERVER?>/common/symbols/rss.png" alt="RSS feed" /></a>
|
<a href="feeds.php?feed=torrents_notify_<?=$N['ID']?>_<?=$LoggedUser['torrent_pass']?>&user=<?=$LoggedUser['ID']?>&auth=<?=$LoggedUser['RSS_Auth']?>&passkey=<?=$LoggedUser['torrent_pass']?>&authkey=<?=$LoggedUser['AuthKey']?>&name=<?=urlencode($N['Label'])?>"><img src="<?=STATIC_SERVER?>/common/symbols/rss.png" alt="RSS feed" /></a>
|
||||||
<?=display_str($N['Label'])?>
|
<?=display_str($N['Label'])?>
|
||||||
@ -39,12 +41,12 @@
|
|||||||
<a href="#" onclick="$('#filter_<?=$N['ID']?>').toggle(); return false;" class="brackets">Show</a>
|
<a href="#" onclick="$('#filter_<?=$N['ID']?>').toggle(); return false;" class="brackets">Show</a>
|
||||||
</h3>
|
</h3>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
<form class="<?=($i>$NumFilters)?'create_form':'edit_form'?>" name="notification" action="user.php" method="post">
|
<form class="<?=($i > $NumFilters) ? 'create_form' : 'edit_form'?>" name="notification" action="user.php" method="post">
|
||||||
<input type="hidden" name="formid" value="<?=$i?>" />
|
<input type="hidden" name="formid" value="<?=$i?>" />
|
||||||
<input type="hidden" name="action" value="notify_handle" />
|
<input type="hidden" name="action" value="notify_handle" />
|
||||||
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
||||||
<table <?=($i<=$NumFilters)?'id="filter_'.$N['ID'].'" class="layout hidden"':'class="layout"'?>>
|
<table <?=($i <= $NumFilters) ? 'id="filter_'.$N['ID'].'" class="layout hidden"' : 'class="layout"'?>>
|
||||||
<? if($i>$NumFilters){ ?>
|
<? if ($i > $NumFilters) { ?>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="label"><strong>Label</strong></td>
|
<td class="label"><strong>Label</strong></td>
|
||||||
<td>
|
<td>
|
||||||
@ -65,7 +67,7 @@
|
|||||||
<td>
|
<td>
|
||||||
<textarea name="artists<?=$i?>" style="width:100%" rows="5"><?=display_str($N['Artists'])?></textarea>
|
<textarea name="artists<?=$i?>" style="width:100%" rows="5"><?=display_str($N['Artists'])?></textarea>
|
||||||
<p class="min_padding">Comma-separated list — e.g. <em>Pink Floyd, Led Zeppelin, Neil Young</em></p>
|
<p class="min_padding">Comma-separated list — e.g. <em>Pink Floyd, Led Zeppelin, Neil Young</em></p>
|
||||||
<input type="checkbox" name="excludeva<?=$i?>" id="excludeva_<?=$N['ID']?>"<? if($N['ExcludeVA']=="1") { echo ' checked="checked"';} ?> />
|
<input type="checkbox" name="excludeva<?=$i?>" id="excludeva_<?=$N['ID']?>"<? if ($N['ExcludeVA'] == '1') { echo ' checked="checked"';} ?> />
|
||||||
<label for="excludeva_<?=$N['ID']?>">Exclude Various Artists releases</label>
|
<label for="excludeva_<?=$N['ID']?>">Exclude Various Artists releases</label>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -86,8 +88,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="label"><strong>Only these categories</strong></td>
|
<td class="label"><strong>Only these categories</strong></td>
|
||||||
<td>
|
<td>
|
||||||
<? foreach($Categories as $Category){ ?>
|
<? foreach ($Categories as $Category) { ?>
|
||||||
<input type="checkbox" name="categories<?=$i?>[]" id="<?=$Category?>_<?=$N['ID']?>" value="<?=$Category?>"<? if(in_array($Category, $N['Categories'])) { echo ' checked="checked"';} ?> />
|
<input type="checkbox" name="categories<?=$i?>[]" id="<?=$Category?>_<?=$N['ID']?>" value="<?=$Category?>"<? if (in_array($Category, $N['Categories'])) { echo ' checked="checked"';} ?> />
|
||||||
<label for="<?=$Category?>_<?=$N['ID']?>"><?=$Category?></label>
|
<label for="<?=$Category?>_<?=$N['ID']?>"><?=$Category?></label>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</td>
|
</td>
|
||||||
@ -95,8 +97,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="label"><strong>Only these types</strong></td>
|
<td class="label"><strong>Only these types</strong></td>
|
||||||
<td>
|
<td>
|
||||||
<? foreach($ReleaseTypes as $ReleaseType){ ?>
|
<? foreach ($ReleaseTypes as $ReleaseType) { ?>
|
||||||
<input type="checkbox" name="releasetypes<?=$i?>[]" id="<?=$ReleaseType?>_<?=$N['ID']?>" value="<?=$ReleaseType?>"<? if(in_array($ReleaseType, $N['ReleaseTypes'])) { echo ' checked="checked"';} ?> />
|
<input type="checkbox" name="releasetypes<?=$i?>[]" id="<?=$ReleaseType?>_<?=$N['ID']?>" value="<?=$ReleaseType?>"<? if (in_array($ReleaseType, $N['ReleaseTypes'])) { echo ' checked="checked"';} ?> />
|
||||||
<label for="<?=$ReleaseType?>_<?=$N['ID']?>"><?=$ReleaseType?></label>
|
<label for="<?=$ReleaseType?>_<?=$N['ID']?>"><?=$ReleaseType?></label>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</td>
|
</td>
|
||||||
@ -104,8 +106,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="label"><strong>Only these formats</strong></td>
|
<td class="label"><strong>Only these formats</strong></td>
|
||||||
<td>
|
<td>
|
||||||
<? foreach($Formats as $Format){ ?>
|
<? foreach ($Formats as $Format) { ?>
|
||||||
<input type="checkbox" name="formats<?=$i?>[]" id="<?=$Format?>_<?=$N['ID']?>" value="<?=$Format?>"<? if(in_array($Format, $N['Formats'])) { echo ' checked="checked"';} ?> />
|
<input type="checkbox" name="formats<?=$i?>[]" id="<?=$Format?>_<?=$N['ID']?>" value="<?=$Format?>"<? if (in_array($Format, $N['Formats'])) { echo ' checked="checked"';} ?> />
|
||||||
<label for="<?=$Format?>_<?=$N['ID']?>"><?=$Format?></label>
|
<label for="<?=$Format?>_<?=$N['ID']?>"><?=$Format?></label>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</td>
|
</td>
|
||||||
@ -113,8 +115,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="label"><strong>Only these bitrates</strong></td>
|
<td class="label"><strong>Only these bitrates</strong></td>
|
||||||
<td>
|
<td>
|
||||||
<? foreach($Bitrates as $Bitrate){ ?>
|
<? foreach ($Bitrates as $Bitrate) { ?>
|
||||||
<input type="checkbox" name="bitrates<?=$i?>[]" id="<?=$Bitrate?>_<?=$N['ID']?>" value="<?=$Bitrate?>"<? if(in_array($Bitrate, $N['Encodings'])) { echo ' checked="checked"';} ?> />
|
<input type="checkbox" name="bitrates<?=$i?>[]" id="<?=$Bitrate?>_<?=$N['ID']?>" value="<?=$Bitrate?>"<? if (in_array($Bitrate, $N['Encodings'])) { echo ' checked="checked"';} ?> />
|
||||||
<label for="<?=$Bitrate?>_<?=$N['ID']?>"><?=$Bitrate?></label>
|
<label for="<?=$Bitrate?>_<?=$N['ID']?>"><?=$Bitrate?></label>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</td>
|
</td>
|
||||||
@ -122,8 +124,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="label"><strong>Only these media</strong></td>
|
<td class="label"><strong>Only these media</strong></td>
|
||||||
<td>
|
<td>
|
||||||
<? foreach($Media as $Medium){ ?>
|
<? foreach ($Media as $Medium) { ?>
|
||||||
<input type="checkbox" name="media<?=$i?>[]" id="<?=$Medium?>_<?=$N['ID']?>" value="<?=$Medium?>"<? if(in_array($Medium, $N['Media'])) { echo ' checked="checked"';} ?> />
|
<input type="checkbox" name="media<?=$i?>[]" id="<?=$Medium?>_<?=$N['ID']?>" value="<?=$Medium?>"<? if (in_array($Medium, $N['Media'])) { echo ' checked="checked"';} ?> />
|
||||||
<label for="<?=$Medium?>_<?=$N['ID']?>"><?=$Medium?></label>
|
<label for="<?=$Medium?>_<?=$N['ID']?>"><?=$Medium?></label>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</td>
|
</td>
|
||||||
@ -139,7 +141,7 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="label"><strong>Only new releases</strong></td>
|
<td class="label"><strong>Only new releases</strong></td>
|
||||||
<td>
|
<td>
|
||||||
<input type="checkbox" name="newgroupsonly<?=$i?>" id="newgroupsonly_<?=$N['ID']?>"<? if($N['NewGroupsOnly']=="1") { echo ' checked="checked"';} ?> />
|
<input type="checkbox" name="newgroupsonly<?=$i?>" id="newgroupsonly_<?=$N['ID']?>"<? if ($N['NewGroupsOnly'] == '1') { echo ' checked="checked"';} ?> />
|
||||||
<label for="newgroupsonly_<?=$N['ID']?>">Only notify for new releases, not new formats</label>
|
<label for="newgroupsonly_<?=$N['ID']?>">Only notify for new releases, not new formats</label>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -150,7 +152,7 @@
|
|||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
</form>
|
</form>
|
||||||
<? if($i==$NumFilters){ ?>
|
<? if ($i == $NumFilters) { ?>
|
||||||
<br /><br />
|
<br /><br />
|
||||||
<? }
|
<? }
|
||||||
} ?>
|
} ?>
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
<?
|
<?
|
||||||
if(!check_perms('site_torrents_notify')){ error(403); }
|
if (!check_perms('site_torrents_notify')) {
|
||||||
|
error(403);
|
||||||
|
}
|
||||||
authorize();
|
authorize();
|
||||||
|
|
||||||
$FormID = '';
|
$FormID = '';
|
||||||
@ -15,114 +17,114 @@
|
|||||||
$ToYear = 0;
|
$ToYear = 0;
|
||||||
$HasFilter = false;
|
$HasFilter = false;
|
||||||
|
|
||||||
if($_POST['formid'] && is_number($_POST['formid'])) {
|
if ($_POST['formid'] && is_number($_POST['formid'])) {
|
||||||
$FormID = $_POST['formid'];
|
$FormID = $_POST['formid'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['artists'.$FormID]){
|
if ($_POST['artists'.$FormID]) {
|
||||||
$Artists = explode(',', $_POST['artists'.$FormID]);
|
$Artists = explode(',', $_POST['artists'.$FormID]);
|
||||||
$ParsedArtists = array();
|
$ParsedArtists = array();
|
||||||
foreach($Artists as $Artist){
|
foreach ($Artists as $Artist) {
|
||||||
if(trim($Artist) != "") {
|
if (trim($Artist) != "") {
|
||||||
$ParsedArtists[] = db_string(trim($Artist));
|
$ParsedArtists[] = db_string(trim($Artist));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(count($ParsedArtists) > 0) {
|
if (count($ParsedArtists) > 0) {
|
||||||
$ArtistList = '|'.implode("|", $ParsedArtists).'|';
|
$ArtistList = '|'.implode("|", $ParsedArtists).'|';
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['excludeva'.$FormID]){
|
if ($_POST['excludeva'.$FormID]) {
|
||||||
$ExcludeVA = '1';
|
$ExcludeVA = '1';
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
} else {
|
} else {
|
||||||
$ExcludeVA = '0';
|
$ExcludeVA = '0';
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['newgroupsonly'.$FormID]){
|
if ($_POST['newgroupsonly'.$FormID]) {
|
||||||
$NewGroupsOnly = '1';
|
$NewGroupsOnly = '1';
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
} else {
|
} else {
|
||||||
$NewGroupsOnly = '0';
|
$NewGroupsOnly = '0';
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['tags'.$FormID]){
|
if ($_POST['tags'.$FormID]) {
|
||||||
$TagList = '|';
|
$TagList = '|';
|
||||||
$Tags = explode(',', $_POST['tags'.$FormID]);
|
$Tags = explode(',', $_POST['tags'.$FormID]);
|
||||||
foreach($Tags as $Tag){
|
foreach ($Tags as $Tag) {
|
||||||
$TagList.=db_string(trim($Tag)).'|';
|
$TagList.=db_string(trim($Tag)).'|';
|
||||||
}
|
}
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['nottags'.$FormID]){
|
if ($_POST['nottags'.$FormID]) {
|
||||||
$NotTagList = '|';
|
$NotTagList = '|';
|
||||||
$Tags = explode(',', $_POST['nottags'.$FormID]);
|
$Tags = explode(',', $_POST['nottags'.$FormID]);
|
||||||
foreach($Tags as $Tag){
|
foreach ($Tags as $Tag) {
|
||||||
$NotTagList.=db_string(trim($Tag)).'|';
|
$NotTagList.=db_string(trim($Tag)).'|';
|
||||||
}
|
}
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['categories'.$FormID]){
|
if ($_POST['categories'.$FormID]) {
|
||||||
$CategoryList = '|';
|
$CategoryList = '|';
|
||||||
foreach($_POST['categories'.$FormID] as $Category){
|
foreach ($_POST['categories'.$FormID] as $Category) {
|
||||||
$CategoryList.=db_string(trim($Category)).'|';
|
$CategoryList.=db_string(trim($Category)).'|';
|
||||||
}
|
}
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['releasetypes'.$FormID]){
|
if ($_POST['releasetypes'.$FormID]) {
|
||||||
$ReleaseTypeList = '|';
|
$ReleaseTypeList = '|';
|
||||||
foreach($_POST['releasetypes'.$FormID] as $ReleaseType){
|
foreach ($_POST['releasetypes'.$FormID] as $ReleaseType) {
|
||||||
$ReleaseTypeList.=db_string(trim($ReleaseType)).'|';
|
$ReleaseTypeList.=db_string(trim($ReleaseType)).'|';
|
||||||
}
|
}
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['formats'.$FormID]){
|
if ($_POST['formats'.$FormID]) {
|
||||||
$FormatList = '|';
|
$FormatList = '|';
|
||||||
foreach($_POST['formats'.$FormID] as $Format){
|
foreach ($_POST['formats'.$FormID] as $Format) {
|
||||||
$FormatList.=db_string(trim($Format)).'|';
|
$FormatList.=db_string(trim($Format)).'|';
|
||||||
}
|
}
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if($_POST['bitrates'.$FormID]){
|
if ($_POST['bitrates'.$FormID]) {
|
||||||
$EncodingList = '|';
|
$EncodingList = '|';
|
||||||
foreach($_POST['bitrates'.$FormID] as $Bitrate){
|
foreach ($_POST['bitrates'.$FormID] as $Bitrate) {
|
||||||
$EncodingList.=db_string(trim($Bitrate)).'|';
|
$EncodingList.=db_string(trim($Bitrate)).'|';
|
||||||
}
|
}
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['media'.$FormID]){
|
if ($_POST['media'.$FormID]) {
|
||||||
$MediaList = '|';
|
$MediaList = '|';
|
||||||
foreach($_POST['media'.$FormID] as $Medium){
|
foreach ($_POST['media'.$FormID] as $Medium) {
|
||||||
$MediaList.=db_string(trim($Medium)).'|';
|
$MediaList.=db_string(trim($Medium)).'|';
|
||||||
}
|
}
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($_POST['fromyear'.$FormID] && is_number($_POST['fromyear'.$FormID])){
|
if ($_POST['fromyear'.$FormID] && is_number($_POST['fromyear'.$FormID])) {
|
||||||
$FromYear = trim($_POST['fromyear'.$FormID]);
|
$FromYear = trim($_POST['fromyear'.$FormID]);
|
||||||
$HasFilter = true;
|
$HasFilter = true;
|
||||||
if($_POST['toyear'.$FormID] && is_number($_POST['toyear'.$FormID])) {
|
if ($_POST['toyear'.$FormID] && is_number($_POST['toyear'.$FormID])) {
|
||||||
$ToYear = trim($_POST['toyear'.$FormID]);
|
$ToYear = trim($_POST['toyear'.$FormID]);
|
||||||
} else {
|
} else {
|
||||||
$ToYear = date('Y')+3;
|
$ToYear = date('Y')+3;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!$HasFilter){
|
if (!$HasFilter) {
|
||||||
$Err = 'You must add at least one criterion to filter by';
|
$Err = 'You must add at least one criterion to filter by';
|
||||||
} elseif(!$_POST['label'.$FormID] && !$_POST['id'.$FormID]) {
|
} elseif (!$_POST['label'.$FormID] && !$_POST['id'.$FormID]) {
|
||||||
$Err = 'You must add a label for the filter set';
|
$Err = 'You must add a label for the filter set';
|
||||||
}
|
}
|
||||||
|
|
||||||
if($Err){
|
if ($Err) {
|
||||||
error($Err);
|
error($Err);
|
||||||
header('Location: user.php?action=notify');
|
header('Location: user.php?action=notify');
|
||||||
die();
|
die();
|
||||||
@ -132,7 +134,7 @@
|
|||||||
$TagList = str_replace('||','|',$TagList);
|
$TagList = str_replace('||','|',$TagList);
|
||||||
$NotTagList = str_replace('||','|',$NotTagList);
|
$NotTagList = str_replace('||','|',$NotTagList);
|
||||||
|
|
||||||
if($_POST['id'.$FormID] && is_number($_POST['id'.$FormID])){
|
if ($_POST['id'.$FormID] && is_number($_POST['id'.$FormID])) {
|
||||||
$DB->query("UPDATE users_notify_filters SET
|
$DB->query("UPDATE users_notify_filters SET
|
||||||
Artists='$ArtistList',
|
Artists='$ArtistList',
|
||||||
ExcludeVA='$ExcludeVA',
|
ExcludeVA='$ExcludeVA',
|
||||||
@ -155,7 +157,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
$Cache->delete_value('notify_filters_'.$LoggedUser['ID']);
|
$Cache->delete_value('notify_filters_'.$LoggedUser['ID']);
|
||||||
if(($Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID'])) !== FALSE && $Notify['ID'] == $_POST['id'.$FormID]) {
|
if (($Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID'])) !== false && $Notify['ID'] == $_POST['id'.$FormID]) {
|
||||||
$Cache->delete_value('notify_artists_'.$LoggedUser['ID']);
|
$Cache->delete_value('notify_artists_'.$LoggedUser['ID']);
|
||||||
}
|
}
|
||||||
header('Location: user.php?action=notify');
|
header('Location: user.php?action=notify');
|
||||||
|
@ -23,33 +23,35 @@
|
|||||||
$Username = db_string($_POST['Username']);
|
$Username = db_string($_POST['Username']);
|
||||||
$Title = db_string($_POST['Title']);
|
$Title = db_string($_POST['Title']);
|
||||||
$AdminComment = db_string($_POST['AdminComment']);
|
$AdminComment = db_string($_POST['AdminComment']);
|
||||||
$Donor = (isset($_POST['Donor']))? 1 : 0;
|
$Donor = (isset($_POST['Donor'])) ? 1 : 0;
|
||||||
$Artist = (isset($_POST['Artist']))? 1 : 0;
|
$Artist = (isset($_POST['Artist'])) ? 1 : 0;
|
||||||
$SecondaryClasses = isset($_POST['secondary_classes'])?$_POST['secondary_classes']:array();
|
$SecondaryClasses = isset($_POST['secondary_classes']) ? $_POST['secondary_classes'] : array();
|
||||||
foreach ($SecondaryClasses as $i => $Val) {
|
foreach ($SecondaryClasses as $i => $Val) {
|
||||||
if(!is_number($Val)) { unset($SecondaryClasses[$i]); }
|
if (!is_number($Val)) {
|
||||||
|
unset($SecondaryClasses[$i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$Visible = (isset($_POST['Visible']))? 1 : 0;
|
$Visible = (isset($_POST['Visible'])) ? 1 : 0;
|
||||||
$Invites = (int)$_POST['Invites'];
|
$Invites = (int)$_POST['Invites'];
|
||||||
$SupportFor = db_string($_POST['SupportFor']);
|
$SupportFor = db_string($_POST['SupportFor']);
|
||||||
$Pass = $_POST['ChangePassword'];
|
$Pass = $_POST['ChangePassword'];
|
||||||
$Warned = (isset($_POST['Warned']))? 1 : 0;
|
$Warned = (isset($_POST['Warned'])) ? 1 : 0;
|
||||||
$Logs095 = (int)$_POST['095logs'];
|
$Logs095 = (int)$_POST['095logs'];
|
||||||
if(isset($_POST['Uploaded']) && isset($_POST['Downloaded'])) {
|
if (isset($_POST['Uploaded']) && isset($_POST['Downloaded'])) {
|
||||||
$Uploaded = ($_POST['Uploaded'] == "" ? 0 : $_POST['Uploaded']);
|
$Uploaded = ($_POST['Uploaded'] == '' ? 0 : $_POST['Uploaded']);
|
||||||
if($Arithmetic = strpbrk($Uploaded, '+-')) {
|
if ($Arithmetic = strpbrk($Uploaded, '+-')) {
|
||||||
$Uploaded += max(-$Uploaded, Format::get_bytes($Arithmetic));
|
$Uploaded += max(-$Uploaded, Format::get_bytes($Arithmetic));
|
||||||
}
|
}
|
||||||
$Downloaded = ($_POST['Downloaded'] == "" ? 0 : $_POST['Downloaded']);
|
$Downloaded = ($_POST['Downloaded'] == '' ? 0 : $_POST['Downloaded']);
|
||||||
if($Arithmetic = strpbrk($Downloaded, '+-')) {
|
if ($Arithmetic = strpbrk($Downloaded, '+-')) {
|
||||||
$Downloaded += max(-$Downloaded, Format::get_bytes($Arithmetic));
|
$Downloaded += max(-$Downloaded, Format::get_bytes($Arithmetic));
|
||||||
}
|
}
|
||||||
if(!is_number($Uploaded) || !is_number($Downloaded)) {
|
if (!is_number($Uploaded) || !is_number($Downloaded)) {
|
||||||
error(0);
|
error(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$FLTokens = isset($_POST['FLTokens'])?$_POST['FLTokens'] : 0;
|
$FLTokens = isset($_POST['FLTokens']) ? $_POST['FLTokens'] : 0;
|
||||||
if(!is_number($FLTokens)) {
|
if (!is_number($FLTokens)) {
|
||||||
error(0);
|
error(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -58,26 +60,26 @@
|
|||||||
$ReduceWarning = (int)$_POST['ReduceWarning'];
|
$ReduceWarning = (int)$_POST['ReduceWarning'];
|
||||||
$WarnReason = $_POST['WarnReason'];
|
$WarnReason = $_POST['WarnReason'];
|
||||||
$UserReason = $_POST['UserReason'];
|
$UserReason = $_POST['UserReason'];
|
||||||
$DisableAvatar = (isset($_POST['DisableAvatar']))? 1 : 0;
|
$DisableAvatar = (isset($_POST['DisableAvatar'])) ? 1 : 0;
|
||||||
$DisableInvites = (isset($_POST['DisableInvites']))? 1 : 0;
|
$DisableInvites = (isset($_POST['DisableInvites'])) ? 1 : 0;
|
||||||
$DisablePosting = (isset($_POST['DisablePosting']))? 1 : 0;
|
$DisablePosting = (isset($_POST['DisablePosting'])) ? 1 : 0;
|
||||||
$DisableForums = (isset($_POST['DisableForums']))? 1 : 0;
|
$DisableForums = (isset($_POST['DisableForums'])) ? 1 : 0;
|
||||||
$DisableTagging = (isset($_POST['DisableTagging']))? 1 : 0;
|
$DisableTagging = (isset($_POST['DisableTagging'])) ? 1 : 0;
|
||||||
$DisableUpload = (isset($_POST['DisableUpload']))? 1 : 0;
|
$DisableUpload = (isset($_POST['DisableUpload'])) ? 1 : 0;
|
||||||
$DisableWiki = (isset($_POST['DisableWiki']))? 1 : 0;
|
$DisableWiki = (isset($_POST['DisableWiki'])) ? 1 : 0;
|
||||||
$DisablePM = (isset($_POST['DisablePM']))? 1 : 0;
|
$DisablePM = (isset($_POST['DisablePM'])) ? 1 : 0;
|
||||||
$DisableIRC = (isset($_POST['DisableIRC']))? 1 : 0;
|
$DisableIRC = (isset($_POST['DisableIRC'])) ? 1 : 0;
|
||||||
$DisableRequests = (isset($_POST['DisableRequests']))? 1 : 0;
|
$DisableRequests = (isset($_POST['DisableRequests'])) ? 1 : 0;
|
||||||
$DisableLeech = (isset($_POST['DisableLeech'])) ? 0 : 1;
|
$DisableLeech = (isset($_POST['DisableLeech'])) ? 0 : 1;
|
||||||
|
|
||||||
$RestrictedForums = db_string(trim($_POST['RestrictedForums']));
|
$RestrictedForums = db_string(trim($_POST['RestrictedForums']));
|
||||||
$PermittedForums = db_string(trim($_POST['PermittedForums']));
|
$PermittedForums = db_string(trim($_POST['PermittedForums']));
|
||||||
$EnableUser = (int)$_POST['UserStatus'];
|
$EnableUser = (int)$_POST['UserStatus'];
|
||||||
$ResetRatioWatch = (isset($_POST['ResetRatioWatch']))? 1 : 0;
|
$ResetRatioWatch = (isset($_POST['ResetRatioWatch'])) ? 1 : 0;
|
||||||
$ResetPasskey = (isset($_POST['ResetPasskey']))? 1 : 0;
|
$ResetPasskey = (isset($_POST['ResetPasskey'])) ? 1 : 0;
|
||||||
$ResetAuthkey = (isset($_POST['ResetAuthkey']))? 1 : 0;
|
$ResetAuthkey = (isset($_POST['ResetAuthkey'])) ? 1 : 0;
|
||||||
$SendHackedMail = (isset($_POST['SendHackedMail']))? 1 : 0;
|
$SendHackedMail = (isset($_POST['SendHackedMail'])) ? 1 : 0;
|
||||||
if($SendHackedMail && !empty($_POST['HackedEmail'])) {
|
if ($SendHackedMail && !empty($_POST['HackedEmail'])) {
|
||||||
$HackedEmail = $_POST['HackedEmail'];
|
$HackedEmail = $_POST['HackedEmail'];
|
||||||
} else {
|
} else {
|
||||||
$SendHackedMail = false;
|
$SendHackedMail = false;
|
||||||
@ -144,7 +146,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//NOW that we know the class of the current user, we can see if one staff member is trying to hax0r us.
|
//NOW that we know the class of the current user, we can see if one staff member is trying to hax0r us.
|
||||||
if(!check_perms('users_mod', $Cur['Class'])) {
|
if (!check_perms('users_mod', $Cur['Class'])) {
|
||||||
//Son of a fucking bitch
|
//Son of a fucking bitch
|
||||||
error(403);
|
error(403);
|
||||||
die();
|
die();
|
||||||
@ -155,7 +157,7 @@
|
|||||||
|
|
||||||
// If we're deleting the user, we can ignore all the other crap
|
// If we're deleting the user, we can ignore all the other crap
|
||||||
|
|
||||||
if ($_POST['UserStatus']=="delete" && check_perms('users_delete_users')) {
|
if ($_POST['UserStatus'] == "delete" && check_perms('users_delete_users')) {
|
||||||
Misc::write_log("User account ".$UserID." (".$Cur['Username'].") was deleted by ".$LoggedUser['Username']);
|
Misc::write_log("User account ".$UserID." (".$Cur['Username'].") was deleted by ".$LoggedUser['Username']);
|
||||||
$DB->query("DELETE FROM users_main WHERE id=".$UserID);
|
$DB->query("DELETE FROM users_main WHERE id=".$UserID);
|
||||||
$DB->query("DELETE FROM users_info WHERE UserID=".$UserID);
|
$DB->query("DELETE FROM users_info WHERE UserID=".$UserID);
|
||||||
@ -174,7 +176,7 @@
|
|||||||
|
|
||||||
if ($_POST['ResetRatioWatch'] && check_perms('users_edit_reset_keys')) {
|
if ($_POST['ResetRatioWatch'] && check_perms('users_edit_reset_keys')) {
|
||||||
$DB->query("UPDATE users_info SET RatioWatchEnds='0000-00-00 00:00:00', RatioWatchDownload='0', RatioWatchTimes='0' WHERE UserID='$UserID'");
|
$DB->query("UPDATE users_info SET RatioWatchEnds='0000-00-00 00:00:00', RatioWatchDownload='0', RatioWatchTimes='0' WHERE UserID='$UserID'");
|
||||||
$EditSummary[]='RatioWatch history reset';
|
$EditSummary[] = 'RatioWatch history reset';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_POST['ResetIPHistory'] && check_perms('users_edit_reset_keys')) {
|
if ($_POST['ResetIPHistory'] && check_perms('users_edit_reset_keys')) {
|
||||||
@ -183,7 +185,7 @@
|
|||||||
$DB->query("UPDATE users_main SET IP='127.0.0.1' WHERE ID='$UserID'");
|
$DB->query("UPDATE users_main SET IP='127.0.0.1' WHERE ID='$UserID'");
|
||||||
$DB->query("UPDATE xbt_snatched SET IP = '' WHERE uid='$UserID'");
|
$DB->query("UPDATE xbt_snatched SET IP = '' WHERE uid='$UserID'");
|
||||||
$DB->query("UPDATE users_history_passwords SET ChangerIP = '' WHERE UserID = ".$UserID);
|
$DB->query("UPDATE users_history_passwords SET ChangerIP = '' WHERE UserID = ".$UserID);
|
||||||
$EditSummary[]='IP history cleared';
|
$EditSummary[] = 'IP history cleared';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_POST['ResetEmailHistory'] && check_perms('users_edit_reset_keys')) {
|
if ($_POST['ResetEmailHistory'] && check_perms('users_edit_reset_keys')) {
|
||||||
@ -194,17 +196,17 @@
|
|||||||
$DB->query("INSERT INTO users_history_emails (UserID, Email, Time, IP) VALUES ('$UserID','$Username@".SITE_URL."','0000-00-00 00:00:00','".$Cur['IP']."')");
|
$DB->query("INSERT INTO users_history_emails (UserID, Email, Time, IP) VALUES ('$UserID','$Username@".SITE_URL."','0000-00-00 00:00:00','".$Cur['IP']."')");
|
||||||
}
|
}
|
||||||
$DB->query("UPDATE users_main SET Email='$Username@".SITE_URL."' WHERE ID='$UserID'");
|
$DB->query("UPDATE users_main SET Email='$Username@".SITE_URL."' WHERE ID='$UserID'");
|
||||||
$EditSummary[]='Email history cleared';
|
$EditSummary[] = 'Email history cleared';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_POST['ResetSnatchList'] && check_perms('users_edit_reset_keys')) {
|
if ($_POST['ResetSnatchList'] && check_perms('users_edit_reset_keys')) {
|
||||||
$DB->query("DELETE FROM xbt_snatched WHERE uid='$UserID'");
|
$DB->query("DELETE FROM xbt_snatched WHERE uid='$UserID'");
|
||||||
$EditSummary[]='Snatch List cleared';
|
$EditSummary[] = 'Snatch list cleared';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_POST['ResetDownloadList'] && check_perms('users_edit_reset_keys')) {
|
if ($_POST['ResetDownloadList'] && check_perms('users_edit_reset_keys')) {
|
||||||
$DB->query("DELETE FROM users_downloads WHERE UserID='$UserID'");
|
$DB->query("DELETE FROM users_downloads WHERE UserID='$UserID'");
|
||||||
$EditSummary[]='Download List cleared';
|
$EditSummary[] = 'Download list cleared';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($_POST['ResetSession'] || $_POST['LogOut']) && check_perms('users_logout')) {
|
if (($_POST['ResetSession'] || $_POST['LogOut']) && check_perms('users_logout')) {
|
||||||
@ -213,7 +215,7 @@
|
|||||||
$Cache->delete_value('user_stats_'.$UserID);
|
$Cache->delete_value('user_stats_'.$UserID);
|
||||||
$Cache->delete_value('enabled_'.$UserID);
|
$Cache->delete_value('enabled_'.$UserID);
|
||||||
|
|
||||||
if($_POST['LogOut']) {
|
if ($_POST['LogOut']) {
|
||||||
$DB->query("SELECT SessionID FROM users_sessions WHERE UserID='$UserID'");
|
$DB->query("SELECT SessionID FROM users_sessions WHERE UserID='$UserID'");
|
||||||
while(list($SessionID) = $DB->next_record()) {
|
while(list($SessionID) = $DB->next_record()) {
|
||||||
$Cache->delete_value('session_'.$UserID.'_'.$SessionID);
|
$Cache->delete_value('session_'.$UserID.'_'.$SessionID);
|
||||||
@ -248,54 +250,54 @@
|
|||||||
|
|
||||||
|
|
||||||
// Start building SQL query and edit summary
|
// Start building SQL query and edit summary
|
||||||
if ($Classes[$Class]['Level']!=$Cur['Class'] && (
|
if ($Classes[$Class]['Level'] != $Cur['Class'] && (
|
||||||
($Classes[$Class]['Level'] < $LoggedUser['Class'] && check_perms('users_promote_below', $Cur['Class']))
|
($Classes[$Class]['Level'] < $LoggedUser['Class'] && check_perms('users_promote_below', $Cur['Class']))
|
||||||
|| ($Classes[$Class]['Level'] <= $LoggedUser['Class'] && check_perms('users_promote_to', $Cur['Class']-1)))) {
|
|| ($Classes[$Class]['Level'] <= $LoggedUser['Class'] && check_perms('users_promote_to', $Cur['Class']-1)))) {
|
||||||
$UpdateSet[]="PermissionID='$Class'";
|
$UpdateSet[] = "PermissionID='$Class'";
|
||||||
$EditSummary[]="class changed to ".Users::make_class_string($Class);
|
$EditSummary[] = "class changed to ".Users::make_class_string($Class);
|
||||||
$LightUpdates['PermissionID']=$Class;
|
$LightUpdates['PermissionID'] = $Class;
|
||||||
$DeleteKeys = true;
|
$DeleteKeys = true;
|
||||||
|
|
||||||
$DB->query("SELECT DISTINCT DisplayStaff FROM permissions WHERE ID = $Class OR ID = ".$ClassLevels[$Cur['Class']]['ID']);
|
$DB->query("SELECT DISTINCT DisplayStaff FROM permissions WHERE ID = $Class OR ID = ".$ClassLevels[$Cur['Class']]['ID']);
|
||||||
if($DB->record_count() == 2) {
|
if ($DB->record_count() == 2) {
|
||||||
if($Classes[$Class]['Level'] < $Cur['Class']) {
|
if ($Classes[$Class]['Level'] < $Cur['Class']) {
|
||||||
$SupportFor = '';
|
$SupportFor = '';
|
||||||
}
|
}
|
||||||
$ClearStaffIDCache = true;
|
$ClearStaffIDCache = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Username!=$Cur['Username'] && check_perms('users_edit_usernames', $Cur['Class']-1)) {
|
if ($Username != $Cur['Username'] && check_perms('users_edit_usernames', $Cur['Class']-1)) {
|
||||||
$DB->query("SELECT ID FROM users_main WHERE Username = '".$Username."'");
|
$DB->query("SELECT ID FROM users_main WHERE Username = '".$Username."'");
|
||||||
if($DB->next_record() > 0) {
|
if ($DB->next_record() > 0) {
|
||||||
list($UsedUsernameID) = $DB->next_record();
|
list($UsedUsernameID) = $DB->next_record();
|
||||||
error("Username already in use by <a href='user.php?id=".$UsedUsernameID."'>".$Username."</a>");
|
error("Username already in use by <a href='user.php?id=".$UsedUsernameID."'>".$Username."</a>");
|
||||||
header("Location: user.php?id=".$UserID);
|
header("Location: user.php?id=".$UserID);
|
||||||
die();
|
die();
|
||||||
} else {
|
} else {
|
||||||
$UpdateSet[]="Username='".$Username."'";
|
$UpdateSet[] = "Username='".$Username."'";
|
||||||
$EditSummary[]="username changed from ".$Cur['Username']." to ".$Username;
|
$EditSummary[] = "username changed from ".$Cur['Username']." to ".$Username;
|
||||||
$LightUpdates['Username']=$Username;
|
$LightUpdates['Username'] = $Username;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Title!=db_string($Cur['Title']) && check_perms('users_edit_titles')) {
|
if ($Title != db_string($Cur['Title']) && check_perms('users_edit_titles')) {
|
||||||
// Using the unescaped value for the test to avoid confusion
|
// Using the unescaped value for the test to avoid confusion
|
||||||
if (strlen($_POST['Title']) > 1024) {
|
if (strlen($_POST['Title']) > 1024) {
|
||||||
error("Custom titles can be at most 1024 characters.");
|
error("Custom titles can be at most 1024 characters.");
|
||||||
header("Location: user.php?id=".$UserID);
|
header("Location: user.php?id=".$UserID);
|
||||||
die();
|
die();
|
||||||
} else {
|
} else {
|
||||||
$UpdateSet[]="Title='$Title'";
|
$UpdateSet[] = "Title='$Title'";
|
||||||
$EditSummary[]="title changed to $Title";
|
$EditSummary[] = "title changed to $Title";
|
||||||
$LightUpdates['Title']=$_POST['Title'];
|
$LightUpdates['Title'] = $_POST['Title'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Donor!=$Cur['Donor'] && check_perms('users_give_donor')) {
|
if ($Donor != $Cur['Donor'] && check_perms('users_give_donor')) {
|
||||||
$UpdateSet[]="Donor='$Donor'";
|
$UpdateSet[] = "Donor='$Donor'";
|
||||||
$EditSummary[]="donor status changed";
|
$EditSummary[] = "donor status changed";
|
||||||
$LightUpdates['Donor']=$Donor;
|
$LightUpdates['Donor'] = $Donor;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Secondary classes
|
// Secondary classes
|
||||||
@ -310,9 +312,9 @@
|
|||||||
$EditSummary[] = "Secondary classes dropped: ".implode(', ',$ClassChanges);
|
$EditSummary[] = "Secondary classes dropped: ".implode(', ',$ClassChanges);
|
||||||
$DB->query("DELETE FROM users_levels WHERE UserID = '$UserID' AND PermissionID IN (".implode(',',$DroppedClasses).")");
|
$DB->query("DELETE FROM users_levels WHERE UserID = '$UserID' AND PermissionID IN (".implode(',',$DroppedClasses).")");
|
||||||
if (count($SecondaryClasses) > 0) {
|
if (count($SecondaryClasses) > 0) {
|
||||||
$LightUpdates['ExtraClasses']= array_fill_keys($SecondaryClasses, 1);
|
$LightUpdates['ExtraClasses'] = array_fill_keys($SecondaryClasses, 1);
|
||||||
} else {
|
} else {
|
||||||
$LightUpdates['ExtraClasses']= array();
|
$LightUpdates['ExtraClasses'] = array();
|
||||||
}
|
}
|
||||||
$DeleteKeys = true;
|
$DeleteKeys = true;
|
||||||
}
|
}
|
||||||
@ -328,92 +330,98 @@
|
|||||||
|
|
||||||
}
|
}
|
||||||
$DB->query("INSERT INTO users_levels (UserID, PermissionID) VALUES ".implode(', ',$Values));
|
$DB->query("INSERT INTO users_levels (UserID, PermissionID) VALUES ".implode(', ',$Values));
|
||||||
//$LightUpdates['ExtraClasses']= array_fill_keys($SecondaryClasses, 1);
|
//$LightUpdates['ExtraClasses'] = array_fill_keys($SecondaryClasses, 1);
|
||||||
$DeleteKeys = true;
|
$DeleteKeys = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Visible!=$Cur['Visible'] && check_perms('users_make_invisible')) {
|
if ($Visible != $Cur['Visible'] && check_perms('users_make_invisible')) {
|
||||||
$UpdateSet[]="Visible='$Visible'";
|
$UpdateSet[] = "Visible='$Visible'";
|
||||||
$EditSummary[]="visibility changed";
|
$EditSummary[] = "visibility changed";
|
||||||
$LightUpdates['Visible']=$Visible;
|
$LightUpdates['Visible'] = $Visible;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Uploaded!=$Cur['Uploaded'] && $Uploaded!=$_POST['OldUploaded'] && (check_perms('users_edit_ratio')
|
if ($Uploaded != $Cur['Uploaded'] && $Uploaded != $_POST['OldUploaded'] && (check_perms('users_edit_ratio')
|
||||||
|| (check_perms('users_edit_own_ratio') && $UserID == $LoggedUser['ID']))) {
|
|| (check_perms('users_edit_own_ratio') && $UserID == $LoggedUser['ID']))) {
|
||||||
$UpdateSet[]="Uploaded='".$Uploaded."'";
|
$UpdateSet[] = "Uploaded='".$Uploaded."'";
|
||||||
$EditSummary[]="uploaded changed from ".Format::get_size($Cur['Uploaded'])." to ".Format::get_size($Uploaded);
|
$EditSummary[] = "uploaded changed from ".Format::get_size($Cur['Uploaded'])." to ".Format::get_size($Uploaded);
|
||||||
$Cache->delete_value('users_stats_'.$UserID);
|
$Cache->delete_value('users_stats_'.$UserID);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Downloaded!=$Cur['Downloaded'] && $Downloaded!=$_POST['OldDownloaded'] && (check_perms('users_edit_ratio')
|
if ($Downloaded != $Cur['Downloaded'] && $Downloaded != $_POST['OldDownloaded'] && (check_perms('users_edit_ratio')
|
||||||
|| (check_perms('users_edit_own_ratio') && $UserID == $LoggedUser['ID']))) {
|
|| (check_perms('users_edit_own_ratio') && $UserID == $LoggedUser['ID']))) {
|
||||||
$UpdateSet[]="Downloaded='".$Downloaded."'";
|
$UpdateSet[] = "Downloaded='".$Downloaded."'";
|
||||||
$EditSummary[]="downloaded changed from ".Format::get_size($Cur['Downloaded'])." to ".Format::get_size($Downloaded);
|
$EditSummary[] = "downloaded changed from ".Format::get_size($Cur['Downloaded'])." to ".Format::get_size($Downloaded);
|
||||||
$Cache->delete_value('users_stats_'.$UserID);
|
$Cache->delete_value('users_stats_'.$UserID);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($FLTokens!=$Cur['FLTokens'] && (check_perms('users_edit_ratio') || (check_perms('users_edit_own_ratio') && $UserID == $LoggedUser['ID']))) {
|
if ($FLTokens != $Cur['FLTokens'] && (check_perms('users_edit_ratio') || (check_perms('users_edit_own_ratio') && $UserID == $LoggedUser['ID']))) {
|
||||||
$UpdateSet[]="FLTokens=".$FLTokens;
|
$UpdateSet[] = "FLTokens=".$FLTokens;
|
||||||
$EditSummary[]="Freeleech Tokens changed from ".$Cur['FLTokens']." to ".$FLTokens;
|
$EditSummary[] = "Freeleech Tokens changed from ".$Cur['FLTokens']." to ".$FLTokens;
|
||||||
$HeavyUpdates['FLTokens'] = $FLTokens;
|
$HeavyUpdates['FLTokens'] = $FLTokens;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Invites!=$Cur['Invites'] && check_perms('users_edit_invites')) {
|
if ($Invites != $Cur['Invites'] && check_perms('users_edit_invites')) {
|
||||||
$UpdateSet[]="invites='$Invites'";
|
$UpdateSet[] = "invites='$Invites'";
|
||||||
$EditSummary[]="number of invites changed to $Invites";
|
$EditSummary[] = "number of invites changed to $Invites";
|
||||||
$HeavyUpdates['Invites'] = $Invites;
|
$HeavyUpdates['Invites'] = $Invites;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Warned == 1 && $Cur['Warned']=='0000-00-00 00:00:00' && check_perms('users_warn')) {
|
if ($Warned == 1 && $Cur['Warned'] == '0000-00-00 00:00:00' && check_perms('users_warn')) {
|
||||||
Misc::send_pm($UserID, 0, 'You have received a warning', "You have been [url=https://".SSL_SITE_URL."/wiki.php?action=article&id=218]warned for $WarnLength week(s)[/url] by [user]".$LoggedUser['Username']."[/user]. The reason given was: $WarnReason");
|
Misc::send_pm($UserID, 0, 'You have received a warning', "You have been [url=https://".SSL_SITE_URL."/wiki.php?action=article&id=218]warned for $WarnLength week(s)[/url] by [user]".$LoggedUser['Username']."[/user]. The reason given was: $WarnReason");
|
||||||
$UpdateSet[]="Warned='".sqltime()."' + INTERVAL $WarnLength WEEK";
|
$UpdateSet[] = "Warned='".sqltime()."' + INTERVAL $WarnLength WEEK";
|
||||||
$Msg = "warned for $WarnLength week(s)";
|
$Msg = "warned for $WarnLength week(s)";
|
||||||
if ($WarnReason) { $Msg.=" for $WarnReason"; }
|
if ($WarnReason) {
|
||||||
$EditSummary[]= db_string($Msg);
|
$Msg.=" for $WarnReason";
|
||||||
$LightUpdates['Warned']=time_plus(3600*24*7*$WarnLength);
|
}
|
||||||
|
$EditSummary[] = db_string($Msg);
|
||||||
|
$LightUpdates['Warned'] = time_plus(3600*24*7*$WarnLength);
|
||||||
|
|
||||||
} elseif ($Warned == 0 && $Cur['Warned']!='0000-00-00 00:00:00' && check_perms('users_warn')) {
|
} elseif ($Warned == 0 && $Cur['Warned'] != '0000-00-00 00:00:00' && check_perms('users_warn')) {
|
||||||
$UpdateSet[]="Warned='0000-00-00 00:00:00'";
|
$UpdateSet[] = "Warned='0000-00-00 00:00:00'";
|
||||||
$EditSummary[]="warning removed";
|
$EditSummary[] = "warning removed";
|
||||||
$LightUpdates['Warned']='0000-00-00 00:00:00';
|
$LightUpdates['Warned'] = '0000-00-00 00:00:00';
|
||||||
|
|
||||||
} elseif ($Warned == 1 && $ExtendWarning!='---' && check_perms('users_warn')) {
|
} elseif ($Warned == 1 && $ExtendWarning != '---' && check_perms('users_warn')) {
|
||||||
|
|
||||||
Misc::send_pm($UserID, 0, 'Your warning has been extended', "Your warning has been extended by $ExtendWarning week(s) by [user]".$LoggedUser['Username']."[/user]. The reason given was: $WarnReason");
|
Misc::send_pm($UserID, 0, 'Your warning has been extended', "Your warning has been extended by $ExtendWarning week(s) by [user]".$LoggedUser['Username']."[/user]. The reason given was: $WarnReason");
|
||||||
|
|
||||||
$UpdateSet[]="Warned=Warned + INTERVAL $ExtendWarning WEEK";
|
$UpdateSet[] = "Warned=Warned + INTERVAL $ExtendWarning WEEK";
|
||||||
$DB->query("SELECT Warned + INTERVAL $ExtendWarning WEEK FROM users_info WHERE UserID='$UserID'");
|
$DB->query("SELECT Warned + INTERVAL $ExtendWarning WEEK FROM users_info WHERE UserID='$UserID'");
|
||||||
list($WarnedUntil) = $DB->next_record();
|
list($WarnedUntil) = $DB->next_record();
|
||||||
$Msg = "warning extended by $ExtendWarning week(s) to $WarnedUntil";
|
$Msg = "warning extended by $ExtendWarning week(s) to $WarnedUntil";
|
||||||
if ($WarnReason) { $Msg.=" for $WarnReason"; }
|
if ($WarnReason) {
|
||||||
$EditSummary[]= db_string($Msg);
|
$Msg.=" for $WarnReason";
|
||||||
$LightUpdates['Warned']=$WarnedUntil;
|
}
|
||||||
} elseif ($Warned == 1 && $ExtendWarning=='---' && $ReduceWarning!='---' && check_perms('users_warn')) {
|
$EditSummary[] = db_string($Msg);
|
||||||
|
$LightUpdates['Warned'] = $WarnedUntil;
|
||||||
|
} elseif ($Warned == 1 && $ExtendWarning == '---' && $ReduceWarning != '---' && check_perms('users_warn')) {
|
||||||
|
|
||||||
Misc::send_pm($UserID, 0, 'Your warning has been reduced', "Your warning has been reduced by $ReduceWarning week(s) by [user]".$LoggedUser['Username']."[/user]. The reason given was: $WarnReason");
|
Misc::send_pm($UserID, 0, 'Your warning has been reduced', "Your warning has been reduced by $ReduceWarning week(s) by [user]".$LoggedUser['Username']."[/user]. The reason given was: $WarnReason");
|
||||||
|
|
||||||
$UpdateSet[]="Warned=Warned - INTERVAL $ReduceWarning WEEK";
|
$UpdateSet[] = "Warned=Warned - INTERVAL $ReduceWarning WEEK";
|
||||||
$DB->query("SELECT Warned - INTERVAL $ReduceWarning WEEK FROM users_info WHERE UserID='$UserID'");
|
$DB->query("SELECT Warned - INTERVAL $ReduceWarning WEEK FROM users_info WHERE UserID='$UserID'");
|
||||||
list($WarnedUntil) = $DB->next_record();
|
list($WarnedUntil) = $DB->next_record();
|
||||||
$Msg = "warning reduced by $ReduceWarning week(s) to $WarnedUntil";
|
$Msg = "warning reduced by $ReduceWarning week(s) to $WarnedUntil";
|
||||||
if ($WarnReason) { $Msg.=" for $WarnReason"; }
|
if ($WarnReason) {
|
||||||
$EditSummary[]= db_string($Msg);
|
$Msg.=" for $WarnReason";
|
||||||
$LightUpdates['Warned']=$WarnedUntil;
|
}
|
||||||
|
$EditSummary[] = db_string($Msg);
|
||||||
|
$LightUpdates['Warned'] = $WarnedUntil;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($SupportFor!=db_string($Cur['SupportFor']) && (check_perms('admin_manage_fls') || (check_perms('users_mod') && $UserID == $LoggedUser['ID']))) {
|
if ($SupportFor != db_string($Cur['SupportFor']) && (check_perms('admin_manage_fls') || (check_perms('users_mod') && $UserID == $LoggedUser['ID']))) {
|
||||||
$UpdateSet[]="SupportFor='$SupportFor'";
|
$UpdateSet[] = "SupportFor='$SupportFor'";
|
||||||
$EditSummary[]="first-line support status changed to $SupportFor";
|
$EditSummary[] = "First-Line Support status changed to $SupportFor";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($RestrictedForums != db_string($Cur['RestrictedForums']) && check_perms('users_mod')) {
|
if ($RestrictedForums != db_string($Cur['RestrictedForums']) && check_perms('users_mod')) {
|
||||||
$UpdateSet[]="RestrictedForums='$RestrictedForums'";
|
$UpdateSet[] = "RestrictedForums='$RestrictedForums'";
|
||||||
$EditSummary[]="restricted forum(s): $RestrictedForums";
|
$EditSummary[] = "restricted forum(s): $RestrictedForums";
|
||||||
$DeleteKeys = true;
|
$DeleteKeys = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($PermittedForums != db_string($Cur['PermittedForums']) && check_perms('users_mod')) {
|
if ($PermittedForums != db_string($Cur['PermittedForums']) && check_perms('users_mod')) {
|
||||||
$ForumSet=explode(',',$PermittedForums);
|
$ForumSet = explode(',',$PermittedForums);
|
||||||
$ForumList = array();
|
$ForumList = array();
|
||||||
foreach ($ForumSet as $ForumID) {
|
foreach ($ForumSet as $ForumID) {
|
||||||
if ($Forums[$ForumID]['MinClassCreate'] <= $LoggedUser['EffectiveClass']) {
|
if ($Forums[$ForumID]['MinClassCreate'] <= $LoggedUser['EffectiveClass']) {
|
||||||
@ -421,152 +429,151 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$PermittedForums = implode(',',$ForumSet);
|
$PermittedForums = implode(',',$ForumSet);
|
||||||
$UpdateSet[]="PermittedForums='$PermittedForums'";
|
$UpdateSet[] = "PermittedForums='$PermittedForums'";
|
||||||
$EditSummary[]="permitted forum(s): $PermittedForums";
|
$EditSummary[] = "permitted forum(s): $PermittedForums";
|
||||||
$DeleteKeys = true;
|
$DeleteKeys = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableAvatar!=$Cur['DisableAvatar'] && check_perms('users_disable_any')) {
|
if ($DisableAvatar != $Cur['DisableAvatar'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisableAvatar='$DisableAvatar'";
|
$UpdateSet[] = "DisableAvatar='$DisableAvatar'";
|
||||||
$EditSummary[]="avatar status changed";
|
$EditSummary[] = "avatar status changed";
|
||||||
$HeavyUpdates['DisableAvatar']=$DisableAvatar;
|
$HeavyUpdates['DisableAvatar'] = $DisableAvatar;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your avatar privileges have been disabled', "Your avatar privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your avatar privileges have been disabled', "Your avatar privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableLeech!=$Cur['can_leech'] && check_perms('users_disable_any')) {
|
if ($DisableLeech != $Cur['can_leech'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="can_leech='$DisableLeech'";
|
$UpdateSet[] = "can_leech='$DisableLeech'";
|
||||||
$EditSummary[]="leeching status changed (".translateLeechStatus($Cur['can_leech'])." -> ".translateLeechStatus($DisableLeech).")";
|
$EditSummary[] = "leeching status changed (".translateLeechStatus($Cur['can_leech'])." -> ".translateLeechStatus($DisableLeech).")";
|
||||||
$HeavyUpdates['DisableLeech']=$DisableLeech;
|
$HeavyUpdates['DisableLeech'] = $DisableLeech;
|
||||||
$HeavyUpdates['CanLeech']=$DisableLeech;
|
$HeavyUpdates['CanLeech'] = $DisableLeech;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your leeching privileges have been disabled', "Your leeching privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your leeching privileges have been disabled', "Your leeching privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
Tracker::update_tracker('update_user', array('passkey' => $Cur['torrent_pass'], 'can_leech' => $DisableLeech));
|
Tracker::update_tracker('update_user', array('passkey' => $Cur['torrent_pass'], 'can_leech' => $DisableLeech));
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableInvites!=$Cur['DisableInvites'] && check_perms('users_disable_any')) {
|
if ($DisableInvites != $Cur['DisableInvites'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisableInvites='$DisableInvites'";
|
$UpdateSet[] = "DisableInvites='$DisableInvites'";
|
||||||
if ($DisableInvites == 1) {
|
if ($DisableInvites == 1) {
|
||||||
//$UpdateSet[]="Invites='0'";
|
//$UpdateSet[] = "Invites='0'";
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your invite privileges have been disabled', "Your invite privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your invite privileges have been disabled', "Your invite privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$EditSummary[]="invites status changed";
|
$EditSummary[] = "invites status changed";
|
||||||
$HeavyUpdates['DisableInvites']=$DisableInvites;
|
$HeavyUpdates['DisableInvites'] = $DisableInvites;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisablePosting!=$Cur['DisablePosting'] && check_perms('users_disable_posts')) {
|
if ($DisablePosting != $Cur['DisablePosting'] && check_perms('users_disable_posts')) {
|
||||||
$UpdateSet[]="DisablePosting='$DisablePosting'";
|
$UpdateSet[] = "DisablePosting='$DisablePosting'";
|
||||||
$EditSummary[]="posting status changed";
|
$EditSummary[] = "posting status changed";
|
||||||
$HeavyUpdates['DisablePosting']=$DisablePosting;
|
$HeavyUpdates['DisablePosting'] = $DisablePosting;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your forum posting privileges have been disabled', "Your forum posting privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your forum posting privileges have been disabled', "Your forum posting privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableForums!=$Cur['DisableForums'] && check_perms('users_disable_posts')) {
|
if ($DisableForums != $Cur['DisableForums'] && check_perms('users_disable_posts')) {
|
||||||
$UpdateSet[]="DisableForums='$DisableForums'";
|
$UpdateSet[] = "DisableForums='$DisableForums'";
|
||||||
$EditSummary[]="forums status changed";
|
$EditSummary[] = "forums status changed";
|
||||||
$HeavyUpdates['DisableForums']=$DisableForums;
|
$HeavyUpdates['DisableForums'] = $DisableForums;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your forum privileges have been disabled', "Your forum privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your forum privileges have been disabled', "Your forum privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableTagging!=$Cur['DisableTagging'] && check_perms('users_disable_any')) {
|
if ($DisableTagging != $Cur['DisableTagging'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisableTagging='$DisableTagging'";
|
$UpdateSet[] = "DisableTagging='$DisableTagging'";
|
||||||
$EditSummary[]="tagging status changed";
|
$EditSummary[] = "tagging status changed";
|
||||||
$HeavyUpdates['DisableTagging']=$DisableTagging;
|
$HeavyUpdates['DisableTagging'] = $DisableTagging;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your tagging privileges have been disabled', "Your tagging privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your tagging privileges have been disabled', "Your tagging privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableUpload!=$Cur['DisableUpload'] && check_perms('users_disable_any')) {
|
if ($DisableUpload != $Cur['DisableUpload'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisableUpload='$DisableUpload'";
|
$UpdateSet[] = "DisableUpload='$DisableUpload'";
|
||||||
$EditSummary[]="upload status changed";
|
$EditSummary[] = "upload status changed";
|
||||||
$HeavyUpdates['DisableUpload']=$DisableUpload;
|
$HeavyUpdates['DisableUpload'] = $DisableUpload;
|
||||||
if ($DisableUpload == 1) {
|
if ($DisableUpload == 1) {
|
||||||
Misc::send_pm($UserID, 0, 'Your upload privileges have been disabled', "Your upload privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your upload privileges have been disabled', "Your upload privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableWiki!=$Cur['DisableWiki'] && check_perms('users_disable_any')) {
|
if ($DisableWiki != $Cur['DisableWiki'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisableWiki='$DisableWiki'";
|
$UpdateSet[] = "DisableWiki='$DisableWiki'";
|
||||||
$EditSummary[]="wiki status changed";
|
$EditSummary[] = "wiki status changed";
|
||||||
$HeavyUpdates['DisableWiki']=$DisableWiki;
|
$HeavyUpdates['DisableWiki'] = $DisableWiki;
|
||||||
$HeavyUpdates['site_edit_wiki']=0;
|
$HeavyUpdates['site_edit_wiki'] = 0;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your site editing privileges have been disabled', "Your site editing privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your site editing privileges have been disabled', "Your site editing privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisablePM!=$Cur['DisablePM'] && check_perms('users_disable_any')) {
|
if ($DisablePM != $Cur['DisablePM'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisablePM='$DisablePM'";
|
$UpdateSet[] = "DisablePM='$DisablePM'";
|
||||||
$EditSummary[]="PM status changed";
|
$EditSummary[] = "PM status changed";
|
||||||
$HeavyUpdates['DisablePM']=$DisablePM;
|
$HeavyUpdates['DisablePM'] = $DisablePM;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your PM privileges have been disabled', "Your PM privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
Misc::send_pm($UserID, 0, 'Your PM privileges have been disabled', "Your PM privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url].");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableIRC!=$Cur['DisableIRC'] && check_perms('users_disable_any')) {
|
if ($DisableIRC != $Cur['DisableIRC'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisableIRC='$DisableIRC'";
|
$UpdateSet[] = "DisableIRC='$DisableIRC'";
|
||||||
$EditSummary[]="IRC status changed";
|
$EditSummary[] = "IRC status changed";
|
||||||
$HeavyUpdates['DisableIRC']=$DisableIRC;
|
$HeavyUpdates['DisableIRC'] = $DisableIRC;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your IRC privileges have been disabled', "Your IRC privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url]. This loss of privileges does not affect the ability to join and talk to staff in #what.cd-disabled.");
|
Misc::send_pm($UserID, 0, 'Your IRC privileges have been disabled', "Your IRC privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url]. This loss of privileges does not affect the ability to join and talk to staff in #what.cd-disabled.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DisableRequests!=$Cur['DisableRequests'] && check_perms('users_disable_any')) {
|
if ($DisableRequests != $Cur['DisableRequests'] && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="DisableRequests='$DisableRequests'";
|
$UpdateSet[] = "DisableRequests='$DisableRequests'";
|
||||||
$EditSummary[]="request status changed";
|
$EditSummary[] = "request status changed";
|
||||||
$HeavyUpdates['DisableRequests']=$DisableRequests;
|
$HeavyUpdates['DisableRequests'] = $DisableRequests;
|
||||||
if (!empty($UserReason)) {
|
if (!empty($UserReason)) {
|
||||||
Misc::send_pm($UserID, 0, 'Your request privileges have been disabled', "Your request privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url]. This loss of privileges does not affect the ability to join and talk to staff in #what.cd-disabled.");
|
Misc::send_pm($UserID, 0, 'Your request privileges have been disabled', "Your request privileges have been disabled. The reason given was: $UserReason. If you would like to discuss this please join ".BOT_DISABLED_CHAN." on our IRC network. Instructions can be found [url=https://".SSL_SITE_URL."/wiki.php?action=article&name=IRC+-+How+to+join]here[/url]. This loss of privileges does not affect the ability to join and talk to staff in #what.cd-disabled.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if ($EnableUser != $Cur['Enabled'] && check_perms('users_disable_users')) {
|
||||||
if ($EnableUser!=$Cur['Enabled'] && check_perms('users_disable_users')) {
|
|
||||||
$EnableStr = 'account '.translateUserStatus($Cur['Enabled']).'->'.translateUserStatus($EnableUser);
|
$EnableStr = 'account '.translateUserStatus($Cur['Enabled']).'->'.translateUserStatus($EnableUser);
|
||||||
if($EnableUser == '2') {
|
if ($EnableUser == '2') {
|
||||||
Tools::disable_users($UserID, '', 1);
|
Tools::disable_users($UserID, '', 1);
|
||||||
} elseif($EnableUser == '1') {
|
} elseif ($EnableUser == '1') {
|
||||||
$Cache->increment('stats_user_count');
|
$Cache->increment('stats_user_count');
|
||||||
Tracker::update_tracker('add_user', array('id' => $UserID, 'passkey' => $Cur['torrent_pass']));
|
Tracker::update_tracker('add_user', array('id' => $UserID, 'passkey' => $Cur['torrent_pass']));
|
||||||
if (($Cur['Downloaded'] == 0) || ($Cur['Uploaded']/$Cur['Downloaded'] >= $Cur['RequiredRatio'])) {
|
if (($Cur['Downloaded'] == 0) || ($Cur['Uploaded']/$Cur['Downloaded'] >= $Cur['RequiredRatio'])) {
|
||||||
$UpdateSet[]="i.RatioWatchEnds='0000-00-00 00:00:00'";
|
$UpdateSet[] = "i.RatioWatchEnds='0000-00-00 00:00:00'";
|
||||||
$CanLeech = 1;
|
$CanLeech = 1;
|
||||||
$UpdateSet[]="m.can_leech='1'";
|
$UpdateSet[] = "m.can_leech='1'";
|
||||||
$UpdateSet[]="i.RatioWatchDownload='0'";
|
$UpdateSet[] = "i.RatioWatchDownload='0'";
|
||||||
} else {
|
} else {
|
||||||
$EnableStr .= ' (Ratio: '.Format::get_ratio_html($Cur['Uploaded'], $Cur['Downloaded'], false).', RR: '.number_format($Cur['RequiredRatio'],2).')';
|
$EnableStr .= ' (Ratio: '.Format::get_ratio_html($Cur['Uploaded'], $Cur['Downloaded'], false).', RR: '.number_format($Cur['RequiredRatio'],2).')';
|
||||||
if ($Cur['RatioWatchEnds'] != '0000-00-00 00:00:00') {
|
if ($Cur['RatioWatchEnds'] != '0000-00-00 00:00:00') {
|
||||||
$UpdateSet[]="i.RatioWatchEnds=NOW()";
|
$UpdateSet[] = "i.RatioWatchEnds=NOW()";
|
||||||
$UpdateSet[]="i.RatioWatchDownload=m.Downloaded";
|
$UpdateSet[] = "i.RatioWatchDownload=m.Downloaded";
|
||||||
$CanLeech = 0;
|
$CanLeech = 0;
|
||||||
}
|
}
|
||||||
Tracker::update_tracker('update_user', array('passkey' => $Cur['torrent_pass'], 'can_leech' => '0'));
|
Tracker::update_tracker('update_user', array('passkey' => $Cur['torrent_pass'], 'can_leech' => '0'));
|
||||||
}
|
}
|
||||||
$UpdateSet[]="Enabled='1'";
|
$UpdateSet[] = "Enabled='1'";
|
||||||
$LightUpdates['Enabled'] = 1;
|
$LightUpdates['Enabled'] = 1;
|
||||||
}
|
}
|
||||||
$EditSummary[]=$EnableStr;
|
$EditSummary[] = $EnableStr;
|
||||||
$Cache->replace_value('enabled_'.$UserID, $EnableUser, 0);
|
$Cache->replace_value('enabled_'.$UserID, $EnableUser, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($ResetPasskey == 1 && check_perms('users_edit_reset_keys')) {
|
if ($ResetPasskey == 1 && check_perms('users_edit_reset_keys')) {
|
||||||
$Passkey = db_string(Users::make_secret());
|
$Passkey = db_string(Users::make_secret());
|
||||||
$UpdateSet[]="torrent_pass='$Passkey'";
|
$UpdateSet[] = "torrent_pass='$Passkey'";
|
||||||
$EditSummary[]="passkey reset";
|
$EditSummary[] = "passkey reset";
|
||||||
$HeavyUpdates['torrent_pass']=$Passkey;
|
$HeavyUpdates['torrent_pass'] = $Passkey;
|
||||||
$Cache->delete_value('user_'.$Cur['torrent_pass']);
|
$Cache->delete_value('user_'.$Cur['torrent_pass']);
|
||||||
//MUST come after the case for updating can_leech.
|
//MUST come after the case for updating can_leech.
|
||||||
|
|
||||||
@ -578,13 +585,13 @@
|
|||||||
|
|
||||||
if ($ResetAuthkey == 1 && check_perms('users_edit_reset_keys')) {
|
if ($ResetAuthkey == 1 && check_perms('users_edit_reset_keys')) {
|
||||||
$Authkey = db_string(Users::make_secret());
|
$Authkey = db_string(Users::make_secret());
|
||||||
$UpdateSet[]="AuthKey='$Authkey'";
|
$UpdateSet[] = "AuthKey='$Authkey'";
|
||||||
$EditSummary[]="authkey reset";
|
$EditSummary[] = "authkey reset";
|
||||||
$HeavyUpdates['AuthKey']=$Authkey;
|
$HeavyUpdates['AuthKey'] = $Authkey;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($SendHackedMail && check_perms('users_disable_any')) {
|
if ($SendHackedMail && check_perms('users_disable_any')) {
|
||||||
$EditSummary[]="hacked email sent to ".$HackedEmail;
|
$EditSummary[] = "hacked email sent to ".$HackedEmail;
|
||||||
Misc::send_email($HackedEmail, "Your ".SITE_NAME." account.","Your ".SITE_NAME." account appears to have been compromised. As a security measure we have disabled your account. To resolve this please visit us on IRC.
|
Misc::send_email($HackedEmail, "Your ".SITE_NAME." account.","Your ".SITE_NAME." account appears to have been compromised. As a security measure we have disabled your account. To resolve this please visit us on IRC.
|
||||||
|
|
||||||
This is the information to connect to our server:
|
This is the information to connect to our server:
|
||||||
@ -602,17 +609,17 @@
|
|||||||
if ($DB->record_count() > 0) {
|
if ($DB->record_count() > 0) {
|
||||||
list($MergeID, $MergeUploaded, $MergeDownloaded) = $DB->next_record();
|
list($MergeID, $MergeUploaded, $MergeDownloaded) = $DB->next_record();
|
||||||
$DB->query("UPDATE users_main AS um JOIN users_info AS ui ON um.ID=ui.UserID SET um.Uploaded = 0, um.Downloaded = 0, ui.AdminComment = CONCAT('".sqltime()." - Stats merged into https://".SSL_SITE_URL."/user.php?id=".$UserID." (".$Cur['Username'].") by ".$LoggedUser['Username']."\n\n', ui.AdminComment) WHERE ID = ".$MergeID);
|
$DB->query("UPDATE users_main AS um JOIN users_info AS ui ON um.ID=ui.UserID SET um.Uploaded = 0, um.Downloaded = 0, ui.AdminComment = CONCAT('".sqltime()." - Stats merged into https://".SSL_SITE_URL."/user.php?id=".$UserID." (".$Cur['Username'].") by ".$LoggedUser['Username']."\n\n', ui.AdminComment) WHERE ID = ".$MergeID);
|
||||||
$UpdateSet[]="Uploaded = Uploaded + '$MergeUploaded'";
|
$UpdateSet[] = "Uploaded = Uploaded + '$MergeUploaded'";
|
||||||
$UpdateSet[]="Downloaded = Downloaded + '$MergeDownloaded'";
|
$UpdateSet[] = "Downloaded = Downloaded + '$MergeDownloaded'";
|
||||||
$EditSummary[]="stats merged from https://".SSL_SITE_URL."/user.php?id=".$MergeID." (".$MergeStatsFrom.")";
|
$EditSummary[] = "stats merged from https://".SSL_SITE_URL."/user.php?id=".$MergeID." (".$MergeStatsFrom.")";
|
||||||
$Cache->delete_value('users_stats_'.$UserID);
|
$Cache->delete_value('users_stats_'.$UserID);
|
||||||
$Cache->delete_value('users_stats_'.$MergeID);
|
$Cache->delete_value('users_stats_'.$MergeID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Pass && check_perms('users_edit_password')) {
|
if ($Pass && check_perms('users_edit_password')) {
|
||||||
$UpdateSet[]="PassHash='".db_string(Users::make_crypt_hash($Pass))."'";
|
$UpdateSet[] = "PassHash='".db_string(Users::make_crypt_hash($Pass))."'";
|
||||||
$EditSummary[]='password reset';
|
$EditSummary[] = 'password reset';
|
||||||
|
|
||||||
$Cache->delete_value('user_info_'.$UserID);
|
$Cache->delete_value('user_info_'.$UserID);
|
||||||
$Cache->delete_value('user_info_heavy_'.$UserID);
|
$Cache->delete_value('user_info_heavy_'.$UserID);
|
||||||
@ -631,15 +638,15 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (empty($UpdateSet) && empty($EditSummary)) {
|
if (empty($UpdateSet) && empty($EditSummary)) {
|
||||||
if(!$Reason) {
|
if (!$Reason) {
|
||||||
if (str_replace("\r", '', $Cur['AdminComment']) != str_replace("\r", '', $AdminComment) && check_perms('users_disable_any')) {
|
if (str_replace("\r", '', $Cur['AdminComment']) != str_replace("\r", '', $AdminComment) && check_perms('users_disable_any')) {
|
||||||
$UpdateSet[]="AdminComment='$AdminComment'";
|
$UpdateSet[] = "AdminComment='$AdminComment'";
|
||||||
} else {
|
} else {
|
||||||
header("Location: user.php?id=$UserID");
|
header("Location: user.php?id=$UserID");
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$EditSummary[]='notes added';
|
$EditSummary[] = 'notes added';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -669,17 +676,17 @@
|
|||||||
|
|
||||||
|
|
||||||
$Summary .= "\n\n".$AdminComment;
|
$Summary .= "\n\n".$AdminComment;
|
||||||
} elseif (empty($UpdateSet) && empty($EditSummary) && $Cur['AdminComment']==$_POST['AdminComment']) {
|
} elseif (empty($UpdateSet) && empty($EditSummary) && $Cur['AdminComment'] == $_POST['AdminComment']) {
|
||||||
$Summary = sqltime().' - '.'Comment added by '.$LoggedUser['Username'].': '.$Reason."\n\n";
|
$Summary = sqltime().' - '.'Comment added by '.$LoggedUser['Username'].': '.$Reason."\n\n";
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(!empty($Summary)) {
|
if (!empty($Summary)) {
|
||||||
$UpdateSet[]="AdminComment='$Summary'";
|
$UpdateSet[] = "AdminComment='$Summary'";
|
||||||
} else {
|
} else {
|
||||||
$UpdateSet[]="AdminComment='$AdminComment'";
|
$UpdateSet[] = "AdminComment='$AdminComment'";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update cache
|
// Update cache
|
||||||
@ -695,7 +702,7 @@
|
|||||||
//die($sql);
|
//die($sql);
|
||||||
$DB->query($sql);
|
$DB->query($sql);
|
||||||
|
|
||||||
if(isset($ClearStaffIDCache)) {
|
if (isset($ClearStaffIDCache)) {
|
||||||
$Cache->delete_value('staff_ids');
|
$Cache->delete_value('staff_ids');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
error(404);
|
error(404);
|
||||||
|
|
||||||
$UserID = $_GET['id'];
|
$UserID = $_GET['id'];
|
||||||
if($UserID == $LoggedUser['ID']) {
|
if ($UserID == $LoggedUser['ID']) {
|
||||||
$OwnProfile = true;
|
$OwnProfile = true;
|
||||||
} else {
|
} else {
|
||||||
$OwnProfile = false;
|
$OwnProfile = false;
|
||||||
@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if(check_perms('users_mod')) { // Person viewing is a staff member
|
if (check_perms('users_mod')) { // Person viewing is a staff member
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
m.Username,
|
m.Username,
|
||||||
m.Email,
|
m.Email,
|
||||||
@ -118,20 +118,20 @@
|
|||||||
|
|
||||||
// Image proxy CTs
|
// Image proxy CTs
|
||||||
$DisplayCustomTitle = $CustomTitle;
|
$DisplayCustomTitle = $CustomTitle;
|
||||||
if(check_perms('site_proxy_images') && !empty($CustomTitle)) {
|
if (check_perms('site_proxy_images') && !empty($CustomTitle)) {
|
||||||
$DisplayCustomTitle = preg_replace_callback('~src=("?)(http.+?)(["\s>])~', function($Matches) {
|
$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];
|
return 'src='.$Matches[1].'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?c=1&i='.urlencode($Matches[2]).$Matches[3];
|
||||||
}, $CustomTitle);
|
}, $CustomTitle);
|
||||||
}
|
}
|
||||||
|
|
||||||
$Paranoia = unserialize($Paranoia);
|
$Paranoia = unserialize($Paranoia);
|
||||||
if(!is_array($Paranoia)) {
|
if (!is_array($Paranoia)) {
|
||||||
$Paranoia = array();
|
$Paranoia = array();
|
||||||
}
|
}
|
||||||
$ParanoiaLevel = 0;
|
$ParanoiaLevel = 0;
|
||||||
foreach($Paranoia as $P) {
|
foreach ($Paranoia as $P) {
|
||||||
$ParanoiaLevel++;
|
$ParanoiaLevel++;
|
||||||
if(strpos($P, '+')) {
|
if (strpos($P, '+')) {
|
||||||
$ParanoiaLevel++;
|
$ParanoiaLevel++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -159,16 +159,16 @@ function check_paranoia_here($Setting) {
|
|||||||
<? if (!$OwnProfile) { ?>
|
<? if (!$OwnProfile) { ?>
|
||||||
<a href="inbox.php?action=compose&to=<?=$UserID?>" class="brackets">Send message</a>
|
<a href="inbox.php?action=compose&to=<?=$UserID?>" class="brackets">Send message</a>
|
||||||
|
|
||||||
<? if(check_perms("users_mod")) {
|
<? if (check_perms("users_mod")) {
|
||||||
$DB->query("SELECT PushService FROM users_push_notifications WHERE UserID = '$UserID'");
|
$DB->query("SELECT PushService FROM users_push_notifications WHERE UserID = '$UserID'");
|
||||||
if($DB->record_count() > 0) { ?>
|
if ($DB->record_count() > 0) { ?>
|
||||||
<a
|
<a
|
||||||
href="user.php?action=take_push&push=1&userid=<?=$UserID?>&auth=<?=$LoggedUser['AuthKey']?>" class="brackets"
|
href="user.php?action=take_push&push=1&userid=<?=$UserID?>&auth=<?=$LoggedUser['AuthKey']?>" class="brackets"
|
||||||
>Push user</a>
|
>Push user</a>
|
||||||
<? }
|
<? }
|
||||||
}
|
}
|
||||||
$DB->query("SELECT FriendID FROM friends WHERE UserID='$LoggedUser[ID]' AND FriendID='$UserID'");
|
$DB->query("SELECT FriendID FROM friends WHERE UserID='$LoggedUser[ID]' AND FriendID='$UserID'");
|
||||||
if($DB->record_count() == 0) { ?>
|
if ($DB->record_count() == 0) { ?>
|
||||||
<a href="friends.php?action=add&friendid=<?=$UserID?>&auth=<?=$LoggedUser['AuthKey']?>" class="brackets">Add to friends</a>
|
<a href="friends.php?action=add&friendid=<?=$UserID?>&auth=<?=$LoggedUser['AuthKey']?>" class="brackets">Add to friends</a>
|
||||||
<? }?>
|
<? }?>
|
||||||
<a href="reports.php?action=report&type=user&id=<?=$UserID?>" class="brackets">Report user</a>
|
<a href="reports.php?action=report&type=user&id=<?=$UserID?>" class="brackets">Report user</a>
|
||||||
@ -209,7 +209,7 @@ function check_paranoia_here($Setting) {
|
|||||||
<div class="sidebar">
|
<div class="sidebar">
|
||||||
<?
|
<?
|
||||||
if ($Avatar && Users::has_avatars_enabled()) {
|
if ($Avatar && Users::has_avatars_enabled()) {
|
||||||
if(check_perms('site_proxy_images') && !empty($Avatar)) {
|
if (check_perms('site_proxy_images') && !empty($Avatar)) {
|
||||||
$Avatar = 'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?c=1&avatar='.$UserID.'&i='.urlencode($Avatar);
|
$Avatar = 'http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?c=1&avatar='.$UserID.'&i='.urlencode($Avatar);
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
@ -265,7 +265,7 @@ function check_paranoia_here($Setting) {
|
|||||||
$RequestsVoted = $TotalSpent = 0;
|
$RequestsVoted = $TotalSpent = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(check_paranoia_here('uploads+')) {
|
if (check_paranoia_here('uploads+')) {
|
||||||
$DB->query("SELECT COUNT(ID) FROM torrents WHERE UserID='$UserID'");
|
$DB->query("SELECT COUNT(ID) FROM torrents WHERE UserID='$UserID'");
|
||||||
list($Uploads) = $DB->next_record();
|
list($Uploads) = $DB->next_record();
|
||||||
} else {
|
} else {
|
||||||
@ -290,9 +290,9 @@ function check_paranoia_here($Setting) {
|
|||||||
$BountyRank = $Rank->get_rank('bounty', $TotalSpent);
|
$BountyRank = $Rank->get_rank('bounty', $TotalSpent);
|
||||||
$ArtistsRank = $Rank->get_rank('artists', $ArtistsAdded);
|
$ArtistsRank = $Rank->get_rank('artists', $ArtistsAdded);
|
||||||
|
|
||||||
if($Downloaded == 0) {
|
if ($Downloaded == 0) {
|
||||||
$Ratio = 1;
|
$Ratio = 1;
|
||||||
} elseif($Uploaded == 0) {
|
} elseif ($Uploaded == 0) {
|
||||||
$Ratio = 0.5;
|
$Ratio = 0.5;
|
||||||
} else {
|
} else {
|
||||||
$Ratio = round($Uploaded/$Downloaded, 2);
|
$Ratio = round($Uploaded/$Downloaded, 2);
|
||||||
@ -388,7 +388,7 @@ function check_paranoia_here($Setting) {
|
|||||||
<li>
|
<li>
|
||||||
<ul class="stats">
|
<ul class="stats">
|
||||||
<?
|
<?
|
||||||
foreach($UserInfo['ExtraClasses'] as $PermID => $Val) { ?>
|
foreach ($UserInfo['ExtraClasses'] as $PermID => $Val) { ?>
|
||||||
<li><?=$Classes[$PermID]['Name']?></li>
|
<li><?=$Classes[$PermID]['Name']?></li>
|
||||||
<? }
|
<? }
|
||||||
?>
|
?>
|
||||||
@ -397,13 +397,13 @@ function check_paranoia_here($Setting) {
|
|||||||
<?
|
<?
|
||||||
}
|
}
|
||||||
// An easy way for people to measure the paranoia of a user, for e.g. contest eligibility
|
// An easy way for people to measure the paranoia of a user, for e.g. contest eligibility
|
||||||
if($ParanoiaLevel == 0) {
|
if ($ParanoiaLevel == 0) {
|
||||||
$ParanoiaLevelText = 'Off';
|
$ParanoiaLevelText = 'Off';
|
||||||
} elseif($ParanoiaLevel == 1) {
|
} elseif ($ParanoiaLevel == 1) {
|
||||||
$ParanoiaLevelText = 'Very Low';
|
$ParanoiaLevelText = 'Very Low';
|
||||||
} elseif($ParanoiaLevel <= 5) {
|
} elseif ($ParanoiaLevel <= 5) {
|
||||||
$ParanoiaLevelText = 'Low';
|
$ParanoiaLevelText = 'Low';
|
||||||
} elseif($ParanoiaLevel <= 20) {
|
} elseif ($ParanoiaLevel <= 20) {
|
||||||
$ParanoiaLevelText = 'High';
|
$ParanoiaLevelText = 'High';
|
||||||
} else {
|
} else {
|
||||||
$ParanoiaLevelText = 'Very high';
|
$ParanoiaLevelText = 'Very high';
|
||||||
@ -441,7 +441,7 @@ function check_paranoia_here($Setting) {
|
|||||||
<li>Invites: <?
|
<li>Invites: <?
|
||||||
$DB->query("SELECT count(InviterID) FROM invites WHERE InviterID = '$UserID'");
|
$DB->query("SELECT count(InviterID) FROM invites WHERE InviterID = '$UserID'");
|
||||||
list($Pending) = $DB->next_record();
|
list($Pending) = $DB->next_record();
|
||||||
if($DisableInvites) {
|
if ($DisableInvites) {
|
||||||
echo 'X';
|
echo 'X';
|
||||||
} else {
|
} else {
|
||||||
echo number_format($Invites);
|
echo number_format($Invites);
|
||||||
@ -503,7 +503,7 @@ function check_paranoia_here($Setting) {
|
|||||||
<?
|
<?
|
||||||
if ($Snatched > 4 && check_paranoia_here('snatched')) {
|
if ($Snatched > 4 && check_paranoia_here('snatched')) {
|
||||||
$RecentSnatches = $Cache->get_value('recent_snatches_'.$UserID);
|
$RecentSnatches = $Cache->get_value('recent_snatches_'.$UserID);
|
||||||
if(!is_array($RecentSnatches)){
|
if (!is_array($RecentSnatches)) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
g.ID,
|
g.ID,
|
||||||
g.Name,
|
g.Name,
|
||||||
@ -520,7 +520,7 @@ function check_paranoia_here($Setting) {
|
|||||||
$RecentSnatches = $DB->to_array();
|
$RecentSnatches = $DB->to_array();
|
||||||
|
|
||||||
$Artists = Artists::get_artists($DB->collect('ID'));
|
$Artists = Artists::get_artists($DB->collect('ID'));
|
||||||
foreach($RecentSnatches as $Key => $SnatchInfo) {
|
foreach ($RecentSnatches as $Key => $SnatchInfo) {
|
||||||
$RecentSnatches[$Key]['Artist'] = Artists::display_artists($Artists[$SnatchInfo['ID']], false, true);
|
$RecentSnatches[$Key]['Artist'] = Artists::display_artists($Artists[$SnatchInfo['ID']], false, true);
|
||||||
}
|
}
|
||||||
$Cache->cache_value('recent_snatches_'.$UserID, $RecentSnatches, 0); //inf cache
|
$Cache->cache_value('recent_snatches_'.$UserID, $RecentSnatches, 0); //inf cache
|
||||||
@ -532,7 +532,7 @@ function check_paranoia_here($Setting) {
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<?
|
<?
|
||||||
foreach($RecentSnatches as $RS) { ?>
|
foreach ($RecentSnatches as $RS) { ?>
|
||||||
<td>
|
<td>
|
||||||
<a href="torrents.php?id=<?=$RS['ID']?>" title="<?=display_str($RS['Artist'])?><?=display_str($RS['Name'])?>"><img src="<?=ImageTools::thumbnail($RS['WikiImage'])?>" alt="<?=display_str($RS['Artist'])?><?=display_str($RS['Name'])?>" width="107" /></a>
|
<a href="torrents.php?id=<?=$RS['ID']?>" title="<?=display_str($RS['Artist'])?><?=display_str($RS['Name'])?>"><img src="<?=ImageTools::thumbnail($RS['WikiImage'])?>" alt="<?=display_str($RS['Artist'])?><?=display_str($RS['Name'])?>" width="107" /></a>
|
||||||
</td>
|
</td>
|
||||||
@ -542,10 +542,12 @@ function check_paranoia_here($Setting) {
|
|||||||
<?
|
<?
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!isset($Uploads)) { $Uploads = 0; }
|
if (!isset($Uploads)) {
|
||||||
|
$Uploads = 0;
|
||||||
|
}
|
||||||
if ($Uploads > 4 && check_paranoia_here('uploads')) {
|
if ($Uploads > 4 && check_paranoia_here('uploads')) {
|
||||||
$RecentUploads = $Cache->get_value('recent_uploads_'.$UserID);
|
$RecentUploads = $Cache->get_value('recent_uploads_'.$UserID);
|
||||||
if(!is_array($RecentUploads)){
|
if (!is_array($RecentUploads)) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
g.ID,
|
g.ID,
|
||||||
g.Name,
|
g.Name,
|
||||||
@ -560,7 +562,7 @@ function check_paranoia_here($Setting) {
|
|||||||
LIMIT 5");
|
LIMIT 5");
|
||||||
$RecentUploads = $DB->to_array();
|
$RecentUploads = $DB->to_array();
|
||||||
$Artists = Artists::get_artists($DB->collect('ID'));
|
$Artists = Artists::get_artists($DB->collect('ID'));
|
||||||
foreach($RecentUploads as $Key => $UploadInfo) {
|
foreach ($RecentUploads as $Key => $UploadInfo) {
|
||||||
$RecentUploads[$Key]['Artist'] = Artists::display_artists($Artists[$UploadInfo['ID']], false, true);
|
$RecentUploads[$Key]['Artist'] = Artists::display_artists($Artists[$UploadInfo['ID']], false, true);
|
||||||
}
|
}
|
||||||
$Cache->cache_value('recent_uploads_'.$UserID, $RecentUploads, 0); //inf cache
|
$Cache->cache_value('recent_uploads_'.$UserID, $RecentUploads, 0); //inf cache
|
||||||
@ -571,7 +573,7 @@ function check_paranoia_here($Setting) {
|
|||||||
<td colspan="5">Recent uploads</td>
|
<td colspan="5">Recent uploads</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<? foreach($RecentUploads as $RU) { ?>
|
<? foreach ($RecentUploads as $RU) { ?>
|
||||||
<td>
|
<td>
|
||||||
<a href="torrents.php?id=<?=$RU['ID']?>" title="<?=$RU['Artist']?><?=$RU['Name']?>"><img src="<?=ImageTools::thumbnail($RU['WikiImage'])?>" alt="<?=$RU['Artist']?><?=$RU['Name']?>" width="107" /></a>
|
<a href="torrents.php?id=<?=$RU['ID']?>" title="<?=$RU['Artist']?><?=$RU['Name']?>"><img src="<?=ImageTools::thumbnail($RU['WikiImage'])?>" alt="<?=$RU['Artist']?><?=$RU['Name']?>" width="107" /></a>
|
||||||
</td>
|
</td>
|
||||||
@ -607,7 +609,7 @@ function check_paranoia_here($Setting) {
|
|||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr class="images<?=$FirstCol ? '' : ' hidden'?>">
|
<tr class="images<?=$FirstCol ? '' : ' hidden'?>">
|
||||||
<? foreach($Collage as $C) {
|
<? foreach ($Collage as $C) {
|
||||||
$Group = Torrents::get_groups(array($C['GroupID']));
|
$Group = Torrents::get_groups(array($C['GroupID']));
|
||||||
$Group = array_pop($Group['matches']);
|
$Group = array_pop($Group['matches']);
|
||||||
extract(Torrents::array_group($Group));
|
extract(Torrents::array_group($Group));
|
||||||
@ -630,7 +632,7 @@ function check_paranoia_here($Setting) {
|
|||||||
|
|
||||||
|
|
||||||
// Linked accounts
|
// Linked accounts
|
||||||
if(check_perms('users_mod')) {
|
if (check_perms('users_mod')) {
|
||||||
include(SERVER_ROOT.'/sections/user/linkedfunctions.php');
|
include(SERVER_ROOT.'/sections/user/linkedfunctions.php');
|
||||||
user_dupes_table($UserID);
|
user_dupes_table($UserID);
|
||||||
}
|
}
|
||||||
@ -666,7 +668,7 @@ function check_paranoia_here($Setting) {
|
|||||||
GROUP BY r.ID
|
GROUP BY r.ID
|
||||||
ORDER BY Votes DESC");
|
ORDER BY Votes DESC");
|
||||||
|
|
||||||
if($DB->record_count() > 0) {
|
if ($DB->record_count() > 0) {
|
||||||
$Requests = $DB->to_array();
|
$Requests = $DB->to_array();
|
||||||
?>
|
?>
|
||||||
<div class="box">
|
<div class="box">
|
||||||
@ -688,12 +690,12 @@ function check_paranoia_here($Setting) {
|
|||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<?
|
<?
|
||||||
foreach($Requests as $Request) {
|
foreach ($Requests as $Request) {
|
||||||
list($RequestID, $CategoryID, $Title, $Year, $TimeAdded, $Votes, $Bounty) = $Request;
|
list($RequestID, $CategoryID, $Title, $Year, $TimeAdded, $Votes, $Bounty) = $Request;
|
||||||
|
|
||||||
$Request = Requests::get_requests(array($RequestID));
|
$Request = Requests::get_requests(array($RequestID));
|
||||||
$Request = $Request['matches'][$RequestID];
|
$Request = $Request['matches'][$RequestID];
|
||||||
if(empty($Request)) {
|
if (empty($Request)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -702,11 +704,11 @@ function check_paranoia_here($Setting) {
|
|||||||
|
|
||||||
$CategoryName = $Categories[$CategoryID - 1];
|
$CategoryName = $Categories[$CategoryID - 1];
|
||||||
|
|
||||||
if($CategoryName == "Music") {
|
if ($CategoryName == "Music") {
|
||||||
$ArtistForm = get_request_artists($RequestID);
|
$ArtistForm = get_request_artists($RequestID);
|
||||||
$ArtistLink = Artists::display_artists($ArtistForm, true, true);
|
$ArtistLink = Artists::display_artists($ArtistForm, true, true);
|
||||||
$FullName = $ArtistLink."<a href='requests.php?action=view&id=".$RequestID."'>".$Title." [".$Year."]</a>";
|
$FullName = $ArtistLink."<a href='requests.php?action=view&id=".$RequestID."'>".$Title." [".$Year."]</a>";
|
||||||
} else if($CategoryName == "Audiobooks" || $CategoryName == "Comedy") {
|
} else if ($CategoryName == "Audiobooks" || $CategoryName == "Comedy") {
|
||||||
$FullName = "<a href='requests.php?action=view&id=".$RequestID."'>".$Title." [".$Year."]</a>";
|
$FullName = "<a href='requests.php?action=view&id=".$RequestID."'>".$Title." [".$Year."]</a>";
|
||||||
} else {
|
} else {
|
||||||
$FullName ="<a href='requests.php?action=view&id=".$RequestID."'>".$Title."</a>";
|
$FullName ="<a href='requests.php?action=view&id=".$RequestID."'>".$Title."</a>";
|
||||||
@ -716,22 +718,22 @@ function check_paranoia_here($Setting) {
|
|||||||
?>
|
?>
|
||||||
<tr class="row<?=$Row?>">
|
<tr class="row<?=$Row?>">
|
||||||
<td>
|
<td>
|
||||||
<?=$FullName?>
|
<?=$FullName ?>
|
||||||
<div class="tags">
|
<div class="tags">
|
||||||
<?
|
<?
|
||||||
$Tags = $Request['Tags'];
|
$Tags = $Request['Tags'];
|
||||||
$TagList = array();
|
$TagList = array();
|
||||||
foreach($Tags as $TagID => $TagName) {
|
foreach ($Tags as $TagID => $TagName) {
|
||||||
$TagList[] = "<a href='requests.php?tags=".$TagName."'>".display_str($TagName)."</a>";
|
$TagList[] = "<a href='requests.php?tags=".$TagName."'>".display_str($TagName)."</a>";
|
||||||
}
|
}
|
||||||
$TagList = implode(', ', $TagList);
|
$TagList = implode(', ', $TagList);
|
||||||
?>
|
?>
|
||||||
<?=$TagList?>
|
<?=$TagList ?>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<span id="vote_count_<?=$RequestID?>"><?=$Votes?></span>
|
<span id="vote_count_<?=$RequestID?>"><?=$Votes?></span>
|
||||||
<? if(check_perms('site_vote')){ ?>
|
<? if (check_perms('site_vote')) { ?>
|
||||||
<a href="javascript:Vote(0, <?=$RequestID?>)" class="brackets">+</a>
|
<a href="javascript:Vote(0, <?=$RequestID?>)" class="brackets">+</a>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</td>
|
</td>
|
||||||
@ -739,7 +741,7 @@ function check_paranoia_here($Setting) {
|
|||||||
<span id="bounty_<?=$RequestID?>"><?=Format::get_size($Bounty)?></span>
|
<span id="bounty_<?=$RequestID?>"><?=Format::get_size($Bounty)?></span>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<?=time_diff($TimeAdded)?>
|
<?=time_diff($TimeAdded) ?>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
@ -777,14 +779,16 @@ function check_paranoia_here($Setting) {
|
|||||||
<td>Assigned to</td>
|
<td>Assigned to</td>
|
||||||
<td>Resolved by</td>
|
<td>Resolved by</td>
|
||||||
</tr>
|
</tr>
|
||||||
<? foreach($StaffPMs as $StaffPM) {
|
<? foreach ($StaffPMs as $StaffPM) {
|
||||||
list($ID, $Subject, $Status, $Level, $AssignedTo, $Date, $ResolverID) = $StaffPM;
|
list($ID, $Subject, $Status, $Level, $AssignedTo, $Date, $ResolverID) = $StaffPM;
|
||||||
// Get assigned
|
// Get assigned
|
||||||
if ($AssignedToUser == '') {
|
if ($AssignedToUser == '') {
|
||||||
// Assigned to class
|
// Assigned to class
|
||||||
$Assigned = ($Level == 0) ? "First Line Support" : $ClassLevels[$Level]['Name'];
|
$Assigned = ($Level == 0) ? "First Line Support" : $ClassLevels[$Level]['Name'];
|
||||||
// No + on Sysops
|
// No + on Sysops
|
||||||
if ($Assigned != 'Sysop') { $Assigned .= "+"; }
|
if ($Assigned != 'Sysop') {
|
||||||
|
$Assigned .= "+";
|
||||||
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// Assigned to user
|
// Assigned to user
|
||||||
@ -814,10 +818,10 @@ function check_paranoia_here($Setting) {
|
|||||||
<?
|
<?
|
||||||
|
|
||||||
// Displays a table of forum warnings viewable only to Forum Moderators
|
// Displays a table of forum warnings viewable only to Forum Moderators
|
||||||
if($LoggedUser['Class'] == 650 && check_perms('users_warn', $Class)) {
|
if ($LoggedUser['Class'] == 650 && check_perms('users_warn', $Class)) {
|
||||||
$DB->query("SELECT Comment FROM users_warnings_forums WHERE UserID = '$UserID'");
|
$DB->query("SELECT Comment FROM users_warnings_forums WHERE UserID = '$UserID'");
|
||||||
list($ForumWarnings) = $DB->next_record();
|
list($ForumWarnings) = $DB->next_record();
|
||||||
if($DB->record_count() > 0) {
|
if ($DB->record_count() > 0) {
|
||||||
?>
|
?>
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<div class="head">Forum warnings</div>
|
<div class="head">Forum warnings</div>
|
||||||
@ -879,10 +883,20 @@ function check_paranoia_here($Setting) {
|
|||||||
<select name="Class">
|
<select name="Class">
|
||||||
<?
|
<?
|
||||||
foreach ($ClassLevels as $CurClass) {
|
foreach ($ClassLevels as $CurClass) {
|
||||||
if (check_perms('users_promote_below', $Class) && $CurClass['ID']>=$LoggedUser['EffectiveClass']) { break; }
|
if (check_perms('users_promote_below', $Class) && $CurClass['ID'] >= $LoggedUser['EffectiveClass']) {
|
||||||
if ($CurClass['ID']>$LoggedUser['EffectiveClass']) { break; }
|
break;
|
||||||
if ($CurClass['Secondary']) { continue; }
|
}
|
||||||
if ($Class===$CurClass['Level']) { $Selected=' selected="selected"'; } else { $Selected=""; }
|
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>
|
<option value="<?=$CurClass['ID']?>"<?=$Selected?>><?=$CurClass['Name'].' ('.$CurClass['Level'].')'?></option>
|
||||||
<? } ?>
|
<? } ?>
|
||||||
@ -915,7 +929,9 @@ function check_paranoia_here($Setting) {
|
|||||||
$i++;
|
$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>
|
<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 />'; }
|
<? if ($i % 5 == 0) {
|
||||||
|
echo '<br />';
|
||||||
|
}
|
||||||
} ?>
|
} ?>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -1109,7 +1125,7 @@ function check_paranoia_here($Setting) {
|
|||||||
<input type="checkbox" name="SendHackedMail" id="SendHackedMail" /> <label for="SendHackedMail">Send hacked account email</label> to
|
<input type="checkbox" name="SendHackedMail" id="SendHackedMail" /> <label for="SendHackedMail">Send hacked account email</label> to
|
||||||
<select name="HackedEmail">
|
<select name="HackedEmail">
|
||||||
<?
|
<?
|
||||||
foreach($Emails as $Email) {
|
foreach ($Emails as $Email) {
|
||||||
list($Address, $IP) = $Email;
|
list($Address, $IP) = $Email;
|
||||||
?>
|
?>
|
||||||
<option value="<?=display_str($Address)?>"><?=display_str($Address)?> - <?=display_str($IP)?></option>
|
<option value="<?=display_str($Address)?>"><?=display_str($Address)?> - <?=display_str($IP)?></option>
|
||||||
@ -1159,7 +1175,7 @@ function check_paranoia_here($Setting) {
|
|||||||
|
|
||||||
<? } ?>
|
<? } ?>
|
||||||
</table><br />
|
</table><br />
|
||||||
<? if(check_perms('users_logout')) { ?>
|
<? if (check_perms('users_logout')) { ?>
|
||||||
<table class="layout">
|
<table class="layout">
|
||||||
<tr class="colhead"><td colspan="2">Session</td></tr>
|
<tr class="colhead"><td colspan="2">Session</td></tr>
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -2,17 +2,17 @@
|
|||||||
// perform the back end of subscribing to collages
|
// perform the back end of subscribing to collages
|
||||||
authorize();
|
authorize();
|
||||||
|
|
||||||
if(!is_number($_GET['collageid'])) {
|
if (!is_number($_GET['collageid'])) {
|
||||||
error(0);
|
error(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!$UserSubscriptions = $Cache->get_value('collage_subs_user_'.$LoggedUser['ID'])) {
|
if (!$UserSubscriptions = $Cache->get_value('collage_subs_user_'.$LoggedUser['ID'])) {
|
||||||
$DB->query('SELECT CollageID FROM users_collage_subs WHERE UserID = '.db_string($LoggedUser['ID']));
|
$DB->query('SELECT CollageID FROM users_collage_subs WHERE UserID = '.db_string($LoggedUser['ID']));
|
||||||
$UserSubscriptions = $DB->collect(0);
|
$UserSubscriptions = $DB->collect(0);
|
||||||
$Cache->cache_value('collage_subs_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
$Cache->cache_value('collage_subs_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(($Key = array_search($_GET['collageid'],$UserSubscriptions)) !== FALSE) {
|
if (($Key = array_search($_GET['collageid'],$UserSubscriptions)) !== false) {
|
||||||
$DB->query('DELETE FROM users_collage_subs WHERE UserID = '.db_string($LoggedUser['ID']).' AND CollageID = '.db_string($_GET['collageid']));
|
$DB->query('DELETE FROM users_collage_subs WHERE UserID = '.db_string($LoggedUser['ID']).' AND CollageID = '.db_string($_GET['collageid']));
|
||||||
unset($UserSubscriptions[$Key]);
|
unset($UserSubscriptions[$Key]);
|
||||||
} else {
|
} else {
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
|
|
||||||
list($Page,$Limit) = Format::page_limit($PerPage);
|
list($Page,$Limit) = Format::page_limit($PerPage);
|
||||||
|
|
||||||
if(($UserInfo = $Cache->get_value('user_info_'.$UserID)) === FALSE) {
|
if(($UserInfo = $Cache->get_value('user_info_'.$UserID)) === false) {
|
||||||
$DB->query("SELECT
|
$DB->query("SELECT
|
||||||
m.Username,
|
m.Username,
|
||||||
m.Enabled,
|
m.Enabled,
|
||||||
@ -202,7 +202,7 @@
|
|||||||
<div class="linkbox">
|
<div class="linkbox">
|
||||||
<?
|
<?
|
||||||
if($ViewingOwn) {
|
if($ViewingOwn) {
|
||||||
if(($UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) === FALSE) {
|
if(($UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) === false) {
|
||||||
$DB->query("SELECT TopicID FROM users_subscriptions WHERE UserID = '$LoggedUser[ID]'");
|
$DB->query("SELECT TopicID FROM users_subscriptions WHERE UserID = '$LoggedUser[ID]'");
|
||||||
$UserSubscriptions = $DB->collect(0);
|
$UserSubscriptions = $DB->collect(0);
|
||||||
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
||||||
|
@ -2,28 +2,28 @@
|
|||||||
// perform the back end of subscribing to topics
|
// perform the back end of subscribing to topics
|
||||||
authorize();
|
authorize();
|
||||||
|
|
||||||
if(!empty($LoggedUser['DisableForums'])) {
|
if (!empty($LoggedUser['DisableForums'])) {
|
||||||
error(403);
|
error(403);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!is_number($_GET['topicid'])) {
|
if (!is_number($_GET['topicid'])) {
|
||||||
error(0);
|
error(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
require(SERVER_ROOT.'/sections/forums/index.php');
|
require(SERVER_ROOT.'/sections/forums/index.php');
|
||||||
$DB->query('SELECT ID FROM forums WHERE forums.ID = (SELECT ForumID FROM forums_topics WHERE ID = '.db_string($_GET['topicid']).')');
|
$DB->query('SELECT ID FROM forums WHERE forums.ID = (SELECT ForumID FROM forums_topics WHERE ID = '.db_string($_GET['topicid']).')');
|
||||||
list($ForumID) = $DB->next_record();
|
list($ForumID) = $DB->next_record();
|
||||||
if(!check_forumperm($ForumID)) {
|
if (!check_forumperm($ForumID)) {
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!$UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) {
|
if (!$UserSubscriptions = $Cache->get_value('subscriptions_user_'.$LoggedUser['ID'])) {
|
||||||
$DB->query('SELECT TopicID FROM users_subscriptions WHERE UserID = '.db_string($LoggedUser['ID']));
|
$DB->query('SELECT TopicID FROM users_subscriptions WHERE UserID = '.db_string($LoggedUser['ID']));
|
||||||
$UserSubscriptions = $DB->collect(0);
|
$UserSubscriptions = $DB->collect(0);
|
||||||
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
$Cache->cache_value('subscriptions_user_'.$LoggedUser['ID'],$UserSubscriptions,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(($Key = array_search($_GET['topicid'],$UserSubscriptions)) !== FALSE) {
|
if (($Key = array_search($_GET['topicid'],$UserSubscriptions)) !== false) {
|
||||||
$DB->query('DELETE FROM users_subscriptions WHERE UserID = '.db_string($LoggedUser['ID']).' AND TopicID = '.db_string($_GET['topicid']));
|
$DB->query('DELETE FROM users_subscriptions WHERE UserID = '.db_string($LoggedUser['ID']).' AND TopicID = '.db_string($_GET['topicid']));
|
||||||
unset($UserSubscriptions[$Key]);
|
unset($UserSubscriptions[$Key]);
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user