mirror of
https://github.com/Shadowss/TravianZ.git
synced 2026-06-28 00:24:23 +00:00
@@ -181,6 +181,14 @@ if($_GET['aid'])
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php
|
||||
// preload villages data
|
||||
$userIDs = [];
|
||||
foreach($aliusers as $user) {
|
||||
$userIDs[] = $user['id'];
|
||||
}
|
||||
$database->getProfileVillages($userIDs);
|
||||
|
||||
// display the page
|
||||
foreach($aliusers as $user)
|
||||
{
|
||||
$rank = $rank + 1;
|
||||
|
||||
@@ -29,12 +29,22 @@ $result = $admin->search_player($_POST['s']);
|
||||
</tr>
|
||||
<?php
|
||||
if($result){
|
||||
for ($i = 0; $i <= count($result)-1; $i++) {
|
||||
$varray = $database->getProfileVillages($result[$i]["id"]);
|
||||
$totalpop = 0;
|
||||
foreach($varray as $vil) {
|
||||
$totalpop += $vil['pop'];
|
||||
}
|
||||
|
||||
// preload villages data
|
||||
$userIDs = [];
|
||||
for ($i = 0; $i <= count($result)-1; $i++) {
|
||||
$userIDs[] = $result[$i]["id"];
|
||||
}
|
||||
$database->getProfileVillages($userIDs);
|
||||
|
||||
// display
|
||||
for ($i = 0; $i <= count($result)-1; $i++) {
|
||||
$varray = $database->getProfileVillages($result[$i]["id"]);
|
||||
$totalpop = 0;
|
||||
|
||||
foreach($varray as $vil) {
|
||||
$totalpop += $vil['pop'];
|
||||
}
|
||||
echo '
|
||||
<tr>
|
||||
<td>'.$result[$i]["id"].'</td>
|
||||
@@ -43,7 +53,8 @@ echo '
|
||||
<td>'.$totalpop.'</td>
|
||||
</tr>
|
||||
';
|
||||
}}
|
||||
}
|
||||
}
|
||||
else{
|
||||
echo '
|
||||
<tr>
|
||||
|
||||
@@ -4644,6 +4644,15 @@ class Automation {
|
||||
global $database;
|
||||
$q = "SELECT id, invited FROM ".TB_PREFIX."users WHERE invited > 0";
|
||||
$array = $database->query_return($q);
|
||||
|
||||
// preload villages data
|
||||
$userIDs = [];
|
||||
foreach($array as $user) {
|
||||
$userIDs[] = $user['id'];
|
||||
}
|
||||
$database->getProfileVillages($userIDs);
|
||||
|
||||
// continue...
|
||||
foreach($array as $user) {
|
||||
$numusers = mysqli_fetch_array(mysqli_query($GLOBALS['link'],"SELECT Count(*) as Total FROM ".TB_PREFIX."users WHERE id = ".(int) $user['invited']), MYSQLI_ASSOC);
|
||||
if($numusers['Total'] > 0){
|
||||
|
||||
+33
-6
@@ -1561,19 +1561,46 @@ class MYSQLi_DB implements IDbConnection {
|
||||
}
|
||||
|
||||
function getProfileVillages($uid, $use_cache = true) {
|
||||
list($uid) = $this->escape_input((int) $uid);
|
||||
$arrayPassed = is_array($uid);
|
||||
|
||||
if (!$arrayPassed) {
|
||||
$uid = [(int) $uid];
|
||||
} else {
|
||||
foreach ($uid as $index => $uidValue) {
|
||||
$uid[$index] = (int) $uidValue;
|
||||
}
|
||||
}
|
||||
|
||||
if (!count($uid)) {
|
||||
return [];
|
||||
}
|
||||
|
||||
// first of all, check if we should be using cache and whether the field
|
||||
// required is already cached
|
||||
if ($use_cache && ($cachedValue = self::returnCachedContent(self::$profileVillagesCache, $uid)) && !is_null($cachedValue)) {
|
||||
if ($use_cache && !$arrayPassed && ($cachedValue = self::returnCachedContent(self::$profileVillagesCache, $uid[0])) && !is_null($cachedValue)) {
|
||||
return $cachedValue;
|
||||
}
|
||||
|
||||
$q = "SELECT capital,wref,name,pop,created from " . TB_PREFIX . "vdata where owner = $uid order by pop desc";
|
||||
$result = mysqli_query($this->dblink,$q);
|
||||
$q = "SELECT capital,wref,name,pop,created,owner from " . TB_PREFIX . "vdata where owner IN(".implode(', ', $uid).") order by pop desc";
|
||||
$result = mysqli_query($this->dblink,$q);
|
||||
|
||||
self::$profileVillagesCache[$uid] = $this->mysqli_fetch_all($result);
|
||||
return self::$profileVillagesCache[$uid];
|
||||
if (!$arrayPassed) {
|
||||
$result = $this->mysqli_fetch_all($result);
|
||||
self::$profileVillagesCache[ $uid[0] ] = $result;
|
||||
} else {
|
||||
// we're preloading, cache all the data individually
|
||||
if (mysqli_num_rows($result)) {
|
||||
while ( $row = mysqli_fetch_array( $result, MYSQLI_ASSOC ) ) {
|
||||
if ( ! isset( self::$profileVillagesCache[ $row['owner'] ] ) ) {
|
||||
self::$profileVillagesCache[ $row['owner'] ] = [];
|
||||
}
|
||||
|
||||
self::$profileVillagesCache[ $row['owner'] ][] = $row;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
// no need to refactor this method
|
||||
|
||||
@@ -126,6 +126,15 @@ if($aid == $session->alliance){
|
||||
<?php
|
||||
// Alliance Member list loop
|
||||
$rank=0;
|
||||
|
||||
// preload villages data
|
||||
$userIDs = [];
|
||||
foreach($memberlist as $member) {
|
||||
$userIDs[] = $member['id'];
|
||||
}
|
||||
$database->getProfileVillages($userIDs);
|
||||
|
||||
// continue...
|
||||
foreach($memberlist as $member) {
|
||||
|
||||
$rank = $rank+1;
|
||||
|
||||
Reference in New Issue
Block a user