query(" DROP TEMPORARY TABLE IF EXISTS temp_stats"); $DB->query(" CREATE TEMPORARY TABLE temp_stats ( ID int(10) NOT NULL PRIMARY KEY AUTO_INCREMENT, Val bigint(20) NOT NULL );"); $DB->query(" INSERT INTO temp_stats (Val) ". $Query); $DB->query(" SELECT COUNT(ID) FROM temp_stats"); list($UserCount) = $DB->next_record(); $DB->query(" SELECT MIN(Val) FROM temp_stats GROUP BY CEIL(ID/(".(int)$UserCount."/100));"); $Table = $DB->to_array(); // Give a little variation to the cache length, so all the tables don't expire at the same time $Cache->cache_value($MemKey, $Table, 3600 * 24 * rand(800, 1000) * 0.001); return $Table; } function table_query($TableName) { switch ($TableName) { case 'uploaded': $Query = " SELECT Uploaded FROM users_main WHERE Enabled='1' AND Uploaded > 0 ORDER BY Uploaded;"; break; case 'downloaded': $Query = " SELECT Downloaded FROM users_main WHERE Enabled='1' AND Downloaded > 0 ORDER BY Downloaded;"; break; case 'uploads': $Query = " SELECT COUNT(t.ID) AS Uploads FROM users_main AS um JOIN torrents AS t ON t.UserID=um.ID WHERE um.Enabled='1' GROUP BY um.ID ORDER BY Uploads;"; break; case 'requests': $Query = " SELECT COUNT(r.ID) AS Requests FROM users_main AS um JOIN requests AS r ON r.FillerID=um.ID WHERE um.Enabled='1' GROUP BY um.ID ORDER BY Requests;"; break; case 'posts': $Query = " SELECT COUNT(p.ID) AS Posts FROM users_main AS um JOIN forums_posts AS p ON p.AuthorID=um.ID WHERE um.Enabled='1' GROUP BY um.ID ORDER BY Posts;"; break; case 'bounty': $Query = " SELECT SUM(rv.Bounty) AS Bounty FROM users_main AS um JOIN requests_votes AS rv ON rv.UserID=um.ID WHERE um.Enabled='1' GROUP BY um.ID ORDER BY Bounty;"; break; case 'artists': $Query = " SELECT COUNT(ta.ArtistID) AS Artists FROM torrents_artists AS ta JOIN torrents_group AS tg ON tg.ID=ta.GroupID JOIN torrents AS t ON t.GroupID = tg.ID WHERE t.UserID != ta.UserID GROUP BY tg.ID ORDER BY Artists ASC"; break; } return $Query; } function get_rank($TableName, $Value) { if ($Value == 0) { return 0; } global $Cache, $DB; $Table = $Cache->get_value(PREFIX.$TableName); if (!$Table) { //Cache lock! $Lock = $Cache->get_value(PREFIX.$TableName."_lock"); if ($Lock) { return false; } else { $Cache->cache_value(PREFIX.$TableName."_lock", '1', 300); $Table = $this->build_table(PREFIX.$TableName, $this->table_query($TableName)); $Cache->delete_value(PREFIX.$TableName."_lock"); } } $LastPercentile = 0; foreach ($Table as $Row) { list($CurValue) = $Row; if ($CurValue >= $Value) { return $LastPercentile; } $LastPercentile++; } return 100; // 100th percentile } function overall_score($Uploaded, $Downloaded, $Uploads, $Requests, $Posts, $Bounty, $Artists, $Ratio) { // We can do this all in 1 line, but it's easier to read this way if ($Ratio > 1) { $Ratio = 1; } $TotalScore = 0; if (in_array(false, func_get_args(), true)) { return false; } $TotalScore += $Uploaded * 15; $TotalScore += $Downloaded * 8; $TotalScore += $Uploads * 25; $TotalScore += $Requests * 2; $TotalScore += $Posts; $TotalScore += $Bounty; $TotalScore += $Artists; $TotalScore /= (15 + 8 + 25 + 2 + 1 + 1 + 1); $TotalScore *= $Ratio; return $TotalScore; } } ?>