function Admin_Debug() { global $session; global $db_prefix; global $GlobalUser; if (method() === "POST") { $query = "SELECT * FROM " . $db_prefix . "debug ORDER BY date DESC, error_id DESC LIMIT 50"; $result = dbquery($query); $rows = dbrows($result); while ($rows--) { $msg = dbarray($result); if ($_POST["delmes" . $msg['error_id']] === "on" || $_POST['deletemessages'] === "deleteall") { $query = "DELETE FROM " . $db_prefix . "debug WHERE error_id = " . $msg['error_id']; dbquery($query); } } } $query = "SELECT * FROM " . $db_prefix . "debug ORDER BY date DESC, error_id DESC LIMIT 50"; $result = dbquery($query); ?> <?php echo AdminPanel(); ?> <table class='header'><tr class='header'><td><table width="519"> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Debug" method="POST"> <tr><td colspan="4" class="c">Сообщения</td></tr> <tr><th>Действие</th><th>Дата</th><th>От</th><th>Браузер</th></tr> <?php $rows = dbrows($result); while ($rows--) { $msg = dbarray($result); $user = LoadUser($msg['owner_id']); $from = "<a href=\"index.php?page=admin&session={$session}&mode=Users&player_id=" . $msg['owner_id'] . "\">" . $user['oname'] . "</a> [" . $msg['ip'] . "]"; $msg['text'] = str_replace("{PUBLIC_SESSION}", $session, $msg['text']); echo "<tr><th><input type=\"checkbox\" name=\"delmes" . $msg['error_id'] . "\"/></th><th>" . date("m-d H:i:s", $msg['date']) . "</th><th>{$from} </th><th>" . $msg['agent'] . " </th></tr>\n"; echo "<tr><td class=\"b\"> </td><td class=\"b\" colspan=\"3\">" . $msg['text'] . "</td></tr>\n"; } ?> <tr><td class="b"> </td><td class="b" colspan="3"></td></tr> <tr><th colspan="4" style='padding:0px 105px;'></th></tr> <tr><th colspan="4"> <select name="deletemessages"> <option value="deletemarked">Удалить выделенные сообщения</option> <option value="deleteall">Удалить все сообщения</option> </select><input type="submit" value="ok" /></th></tr> <tr><td colspan="4"><center> </center></td></tr> </form> </table> <?php }
function Admin_Browse() { global $session; global $db_prefix; global $GlobalUser; $query = "SELECT * FROM " . $db_prefix . "browse ORDER BY date DESC LIMIT 50"; $result = dbquery($query); AdminPanel(); $rows = dbrows($result); echo "Последняя история переходов (50 записей):<br>"; echo "<table>\n"; while ($rows--) { $log = dbarray($result); $user = LoadUser($log['owner_id']); ?> <tr><td><table> <tr> <th> <?php echo $user['oname']; ?> </th> <th> <?php echo $log['url']; ?> </th> </tr> <tr> <th rowspan=2> <?php echo $log['method']; ?> <br> <?php echo date("d M Y", $log['date']); ?> <br> <?php echo date("H:i:s", $log['date']); ?> </th> <th> <?php echo print_r(unserialize($log['getdata'])); ?> </th> </tr> <tr> <th> <?php echo print_r(unserialize($log['postdata'])); ?> </th> </tr> </table></td></tr> <?php } echo "</table>\n"; }
function Admin_Reports() { global $session; global $db_prefix; global $GlobalUser; // Обработка POST-запроса. if (method() === "POST") { } ?> <?php echo AdminPanel(); ?> TODO <?php }
function Admin_Expedition() { global $session; global $db_prefix; global $GlobalUser; // Обработка POST-запроса. if (method() === "POST") { } ?> <?php echo AdminPanel(); ?> TODO: Планируется переработка параметров экспедиции.<br><br> <?php $exptab = LoadExpeditionSettings(); print_r($exptab); }
function Admin_Users() { global $session; global $db_prefix; global $GlobalUser; global $FleetMissionList; $now = time(); $resmap = array(106, 108, 109, 110, 111, 113, 114, 115, 117, 118, 120, 121, 122, 123, 124, 199); $unitab = LoadUniverse(); $speed = $unitab['speed']; // Обработка POST-запроса. if (method() === "POST" && $GlobalUser['admin'] >= 2) { if (key_exists('player_id', $_GET)) { $player_id = intval($_GET['player_id']); } else { $player_id = 0; } if (key_exists('action', $_GET) && $player_id) { $action = $_GET['action']; } else { $action = ""; } if ($action === "update") { $query = "UPDATE " . $db_prefix . "users SET "; foreach ($resmap as $i => $gid) { $query .= "r{$gid} = " . intval($_POST["r{$gid}"]) . ", "; } if ($_POST['deaktjava'] === "on") { $query .= "disable = 1, disable_until = " . ($now + 7 * 24 * 60 * 60) . ", "; } else { $query .= "disable = 0, "; } if ($_POST['vacation'] === "on") { $query .= "vacation = 1, vacation_until = " . ($now + 2 * 24 * 60 * 60 / $speed) . ", "; } else { $query .= "vacation = 0, "; } if ($_POST['banned'] !== "on") { $query .= "banned = 0, "; } if ($_POST['noattack'] !== "on") { $query .= "noattack = 0, "; } $query .= "pemail = '" . $_POST['pemail'] . "', "; $query .= "email = '" . $_POST['email'] . "', "; $query .= "admin = '" . $_POST['admin'] . "', "; $query .= "validated = " . ($_POST['validated'] === "on" ? 1 : 0) . ", "; $query .= "sniff = " . ($_POST['sniff'] === "on" ? 1 : 0) . ", "; $query .= "debug = " . ($_POST['debug'] === "on" ? 1 : 0) . ", "; $query .= "dm = '" . intval($_POST['dm']) . "', "; $query .= "dmfree = '" . intval($_POST['dmfree']) . "', "; $query .= "sortby = '" . intval($_POST['settings_sort']) . "', "; $query .= "sortorder = '" . intval($_POST['settings_order']) . "', "; $query .= "skin = '" . $_POST['dpath'] . "', "; $query .= "useskin = " . ($_POST['design'] === "on" ? 1 : 0) . ", "; $query .= "deact_ip = " . ($_POST['deact_ip'] === "on" ? 1 : 0) . ", "; $query .= "maxspy = '" . intval($_POST['spio_anz']) . "', "; $query .= "maxfleetmsg = '" . intval($_POST['settings_fleetactions']) . "' "; $query .= " WHERE player_id={$player_id};"; dbquery($query); $qname = array('CommanderOff', 'AdmiralOff', 'EngineerOff', 'GeologeOff', 'TechnocrateOff'); foreach ($qname as $i => $qcmd) { $days = intval($_POST[$qcmd]); if ($days > 0) { RecruitOfficer($player_id, $qcmd, $days * 24 * 60 * 60); } } } if ($action === "create_planet") { $g = $_POST['g']; if ($g === "") { $g = 1; } $s = $_POST['s']; if ($s === "") { $s = 1; } $p = $_POST['p']; if ($p === "") { $p = 1; } if (!HasPlanet($g, $s, $p)) { $planet_id = CreatePlanet($g, $s, $p, $_GET['player_id']); $query = "UPDATE " . $db_prefix . "planets SET mprod = 0, kprod = 0, dprod = 0 WHERE planet_id = " . $planet_id; dbquery($query); } } } // Обработка GET-запроса. if (method() === "GET" && $GlobalUser['admin'] >= 2) { if (key_exists('player_id', $_GET)) { $player_id = intval($_GET['player_id']); } else { $player_id = 0; } if (key_exists('action', $_GET) && $player_id) { $action = $_GET['action']; } else { $action = ""; } $now = time(); if ($action === "recalc_stats") { RecalcStats($player_id); RecalcRanks(); } if ($action === "reactivate") { ReactivateUser($player_id); } if ($action === "bot_start") { StartBot($player_id); } if ($action === "bot_stop") { StopBot($player_id); } } if (key_exists("player_id", $_GET)) { // Информация об игроке InvalidateUserCache(); $user = LoadUser(intval($_GET['player_id'])); ?> <?php echo AdminPanel(); ?> <table> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Users&action=update&player_id=<?php echo $user['player_id']; ?> " method="POST" > <tr><td class=c><?php echo AdminUserName($user); ?> </td><td class=c>Настройки</td><td class=c>Исследования</td></tr> <th valign=top><table> <tr><th>ID</th><th><?php echo $user['player_id']; ?> </th></tr> <tr><th>Дата регистрации</th><th><?php echo date("Y-m-d H:i:s", $user['regdate']); ?> </th></tr> <tr><th>Альянс</th><th> <?php if ($user['ally_id']) { $ally = LoadAlly($user['ally_id']); echo "[" . $ally['tag'] . "] " . $ally['name']; } ?> </th></tr> <tr><th>Дата вступления</th><th> <?php if ($user['ally_id']) { echo date("Y-m-d H:i:s", $user['joindate']); } ?> </th></tr> <tr><th>Постоянный адрес</th><th><input type="text" name="pemail" maxlength="100" size="20" value="<?php echo $user['pemail']; ?> " /></th></tr> <tr><th>Временный адрес</th><th><input type="text" name="email" maxlength="100" size="20" value="<?php echo $user['email']; ?> " /></th></tr> <tr><th>Удалить игрока</th><th><input type="checkbox" name="deaktjava" <?php echo IsChecked($user, "disable"); ?> /> <?php if ($user['disable']) { echo date("Y-m-d H:i:s", $user['disable_until']); } ?> </th></tr> <tr><th>Режим отпуска</th><th><input type="checkbox" name="vacation" <?php echo IsChecked($user, "vacation"); ?> /> <?php if ($user['vacation']) { echo date("Y-m-d H:i:s", $user['vacation_until']); } ?> </th></tr> <tr><th>Заблокирован</th><th><input type="checkbox" name="banned" <?php echo IsChecked($user, "banned"); ?> /> <?php if ($user['banned']) { echo date("Y-m-d H:i:s", $user['banned_until']); } ?> </th></tr> <tr><th>Бан атак</th><th><input type="checkbox" name="noattack" <?php echo IsChecked($user, "noattack"); ?> /> <?php if ($user['noattack']) { echo date("Y-m-d H:i:s", $user['noattack_until']); } ?> </th></tr> <tr><th>Последний вход</th><th><?php echo date("Y-m-d H:i:s", $user['lastlogin']); ?> </th></tr> <tr><th>Активность</th><th> <?php $now = time(); echo date("Y-m-d H:i:s", $user['lastclick']); if ($now - $user['lastclick'] < 60 * 60) { echo " (" . floor(($now - $user['lastclick']) / 60) . " min)"; } ?> </th></tr> <tr><th>IP адрес</th><th><a href="http://nic.ru/whois/?query=<?php echo $user['ip_addr']; ?> " target=_blank><?php echo $user['ip_addr']; ?> </a></th></tr> <tr><th>Активирован</th><th><input type="checkbox" name="validated" <?php echo IsChecked($user, "validated"); ?> /> <a href="index.php?page=admin&session=<?php echo $session; ?> &mode=Users&action=reactivate&player_id=<?php echo $user['player_id']; ?> ">выслать пароль</a></th></tr> <tr><th>Главная планета</th><th> <?php $planet = GetPlanet($user['hplanetid']); echo "[" . $planet['g'] . ":" . $planet['s'] . ":" . $planet['p'] . "] <a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $planet['planet_id'] . "\">" . $planet['name'] . "</a>"; ?> </th></tr> <tr><th>Текущая планета</th><th> <?php $planet = GetPlanet($user['aktplanet']); echo "[" . $planet['g'] . ":" . $planet['s'] . ":" . $planet['p'] . "] <a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $planet['planet_id'] . "\">" . $planet['name'] . "</a>"; ?> </th></tr> <tr><th>Права</th><th> <select name="admin"> <option value="0" <?php echo IsSelected($user, "admin", 0); ?> >Пользователь</option> <option value="1" <?php echo IsSelected($user, "admin", 1); ?> >Оператор</option> <option value="2" <?php echo IsSelected($user, "admin", 2); ?> >Администратор</option> </select> </th></tr> <tr><th>Включить слежение</th><th><input type="checkbox" name="sniff" <?php echo IsChecked($user, "sniff"); ?> /></th></tr> <tr><th>Отладочная информация</th><th><input type="checkbox" name="debug" <?php echo IsChecked($user, "debug"); ?> /></th></tr> <?php if (IsBot($user['player_id'])) { ?> <tr><th colspan=2><a href="index.php?page=admin&session=<?php echo $session; ?> &mode=Users&action=bot_stop&player_id=<?php echo $user['player_id']; ?> " >[Остановить бота]</a></th></tr> <?php } else { ?> <tr><th colspan=2><a href="index.php?page=admin&session=<?php echo $session; ?> &mode=Users&action=bot_start&player_id=<?php echo $user['player_id']; ?> " >[Запустить бота]</a></th></tr> <?php } ?> </table></th> <th valign=top><table> <tr><th>Сортировка планет</th><th> <select name="settings_sort"> <option value="0" <?php echo IsSelected($user, "sortby", 0); ?> >порядку колонизации</option> <option value="1" <?php echo IsSelected($user, "sortby", 1); ?> >координатам</option> <option value="2" <?php echo IsSelected($user, "sortby", 2); ?> >алфавиту</option> </select> </th></tr> <tr><th>Порядок сортировки</th><th> <select name="settings_order"> <option value="0" <?php echo IsSelected($user, "sortorder", 0); ?> >по возрастанию</option> <option value="1" <?php echo IsSelected($user, "sortorder", 1); ?> >по убыванию</option> </select> </th></tr> <tr><th>Скин</th><th><input type=text name="dpath" maxlength="80" size="40" value="<?php echo $user['skin']; ?> " /></th></tr> <tr><th>Использовать скин</th><th><input type="checkbox" name="design" <?php echo IsChecked($user, "useskin"); ?> /></th></tr> <tr><th>Декативировать проверку IP</th><th><input type="checkbox" name="deact_ip" <?php echo IsChecked($user, "deact_ip"); ?> /></th></tr> <tr><th>Количество зондов</th><th><input type="text" name="spio_anz" maxlength="2" size="2" value="<?php echo $user['maxspy']; ?> " /></th></tr> <tr><th>Количество сообщений флота</th><th><input type="text" name="settings_fleetactions" maxlength="2" size="2" value="<?php echo $user['maxfleetmsg']; ?> " /></th></tr> <tr><th colspan=2> </th></tr> <tr><td class=c colspan=2>Статистика</td></tr> <tr><th>Очки (старые)</th><th><?php echo nicenum($user['oldscore1'] / 1000); ?> / <?php echo nicenum($user['oldplace1']); ?> </th></tr> <tr><th>Флот (старые)</th><th><?php echo nicenum($user['oldscore2']); ?> / <?php echo nicenum($user['oldplace2']); ?> </th></tr> <tr><th>Исследования (старые)</th><th><?php echo nicenum($user['oldscore3']); ?> / <?php echo nicenum($user['oldplace3']); ?> </th></tr> <tr><th>Очки</th><th><?php echo nicenum($user['score1'] / 1000); ?> / <?php echo nicenum($user['place1']); ?> </th></tr> <tr><th>Флот</th><th><?php echo nicenum($user['score2']); ?> / <?php echo nicenum($user['place2']); ?> </th></tr> <tr><th>Исследования</th><th><?php echo nicenum($user['score3']); ?> / <?php echo nicenum($user['place3']); ?> </th></tr> <tr><th>Дата старой статистики</th><th><?php echo date("Y-m-d H:i:s", $user['scoredate']); ?> </th></tr> <tr><th colspan=2><a href="index.php?page=admin&session=<?php echo $session; ?> &mode=Users&action=recalc_stats&player_id=<?php echo $user['player_id']; ?> " >[Пересчитать статистику]</a></th></tr> <tr><th colspan=2> </th></tr> <tr><td class=c colspan=2>Офицеры</td></tr> <tr><th colspan=2><table><tr> <?php $oname = array('Командир ОГейма', 'Адмирал', 'Инженер', 'Геолог', 'Технократ'); $odesc = array('', '<font size=1 color=skyblue>&nbsp;Макс. кол-во флотов +2</font>', '<font size=1 color=skyblue>Сокращает вдвое потери в обороне+10% больше энергии</font>', '<font size=1 color=skyblue>+10% доход от шахты</font>', '<font size=1 color=skyblue>+2 уровень шпионажа, 25% меньше времени на исследования</font>'); $qname = array('CommanderOff', 'AdmiralOff', 'EngineerOff', 'GeologeOff', 'TechnocrateOff'); $imgname = array('commander', 'admiral', 'ingenieur', 'geologe', 'technokrat'); $now = time(); foreach ($qname as $i => $qcmd) { $end = GetOfficerLeft($user['player_id'], $qname[$i]); $img = ""; if ($end <= $now) { $img = "_un"; $days = ""; } else { $d = ($end - $now) / (60 * 60 * 24); if ($d > 0) { $days = "<font color=lime>Активен</font> ещё " . ceil($d) . " д."; } } echo " <td align='center' width='35' class='header'>\n"; echo "\t<img border='0' src='img/" . $imgname[$i] . "_ikon" . $img . ".gif' width='32' height='32' alt='" . $oname[$i] . "'\n"; echo "\tonmouseover=\"return overlib('<center><font size=1 color=white><b>" . $days . "<br>" . $oname[$i] . "</font><br>" . $odesc[$i] . "<br></b></center>', LEFT, WIDTH, 150);\" onmouseout='return nd();'>\n"; echo " </td> <td><input type=\"text\" name=\"" . $qname[$i] . "\" size=\"3\" /></td>\n\n"; } ?> </tr></table></th></tr> <tr><th colspan=2><i>Чтобы продлить офицера укажите необходимое количество дней в полях ввода</i></th></tr> </table></th> <th valign=top><table> <?php foreach ($resmap as $i => $gid) { echo "<tr><th>" . loca("NAME_{$gid}") . "</th><th><input type=\"text\" size=3 name=\"r{$gid}\" value=\"" . $user["r{$gid}"] . "\" /></th></tr>\n"; } ?> <tr><th>Найденная Тёмная Материя</th><th><input type="text" size=5 name="dmfree" value="<?php echo $user['dmfree']; ?> " /></th></tr> <tr><th>Покупная Тёмная Материя</th><th><input type="text" size=5 name="dm" value="<?php echo $user['dm']; ?> " /></th></tr> </table></th> <tr><th colspan=3><input type="submit" value="Сохранить" /></th></tr> </form> </table> <br> <table> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Users&action=create_planet&player_id=<?php echo $user['player_id']; ?> " method="POST" > <tr><td class=c colspan=20>Список планет</td></tr> <tr> <?php $query = "SELECT * FROM " . $db_prefix . "planets WHERE owner_id = '" . intval($_GET['player_id']) . "' ORDER BY g ASC, s ASC, p ASC, type DESC"; $result = dbquery($query); $rows = dbrows($result); $counter = 0; while ($rows--) { $p = dbarray($result); ?> <td> <img src="<?php echo GetPlanetSmallImage("../evolution/", $p); ?> " width="32px" height="32px"></td> <td> <a href="index.php?page=admin&session=<?php echo $session; ?> &mode=Planets&cp=<?php echo $p['planet_id']; ?> "> <?php echo $p['name']; ?> </a> [<a href="index.php?page=galaxy&session=<?php echo $session; ?> &galaxy=<?php echo $p['g']; ?> &system=<?php echo $p['s']; ?> "><?php echo $p['g']; ?> :<?php echo $p['s']; ?> :<?php echo $p['p']; ?> </a>] </td> <?php $counter++; if ($counter > 9) { $counter = 0; echo "</tr>\n<tr>\n"; } } ?> </tr> <tr><td colspan=20> Координаты: <input name="g" size=2> <input name="s" size=2> <input name="p" size=2> <input type="submit" value="Создать планету"></td></tr> </form> </table> <br> <table> <?php if ($_GET['action'] === 'fleetlogs') { echo "<tr><td class=c colspan=12>Логи полётов</td></tr>\n"; if ($_GET['from'] == 1) { $result = FleetlogsFromPlayer($user['player_id'], $FleetMissionList[$_GET['mission']]); } else { $result = FleetlogsToPlayer($user['player_id'], $FleetMissionList[$_GET['mission']]); } $anz = $rows = dbrows($result); echo "<tr><td class=c>N</td> <td class=c>Таймер</td> <td class=c>Задание</td> <td class=c>Отправлен</td> <td class=c>Прибывает</td><td class=c>Время полёта</td> <td class=c>Старт</td> <td class=c>Цель</td> <td class=c>Флот</td> <td class=c>Ресурсы на планете</td> <td class=c>Груз</td> <td class=c>САБ</td> </tr>\n"; $bxx = 1; while ($rows--) { $fleet_obj = dbarray($result); $fleet_price = FleetPrice($fleet_obj); $points = $fleet_price['points']; $fpoints = $fleet_price['fpoints']; $style = ""; if ($points >= 100000000) { if ($fleet_obj['mission'] <= 2) { $style = " style=\"background-color: FireBrick;\" "; } else { $style = " style=\"background-color: DarkGreen;\" "; } } ?> <tr <?php echo $style; ?> > <th <?php echo $style; ?> > <?php echo $bxx; ?> </th> <th <?php echo $style; ?> > <?php echo "<table><tr {$style} ><th {$style} ><div id='bxx" . $bxx . "' title='" . ($fleet_obj['end'] - $now) . "' star='" . $fleet_obj['start'] . "'> </th>"; echo "<tr><th {$style} >" . date("d.m.Y H:i:s", $fleet_obj['end']) . "</th></tr></table>"; ?> </th> <th <?php echo $style; ?> > <?php echo FleetlogsMissionText($fleet_obj['mission']); ?> </th> <th <?php echo $style; ?> ><?php echo date("d.m.Y", $fleet_obj['start']); ?> <br> <?php echo date("H:i:s", $fleet_obj['start']); ?> </th> <th <?php echo $style; ?> ><?php echo date("d.m.Y", $fleet_obj['end']); ?> <br> <?php echo date("H:i:s", $fleet_obj['end']); ?> </th> <th <?php echo $style; ?> > <?php echo "<nobr>" . BuildDurationFormat($fleet_obj['flight_time']) . "</nobr><br>"; echo "<nobr>" . $fleet_obj['flight_time'] . " сек.</nobr>"; ?> </th> <th <?php echo $style; ?> > <?php echo "[" . $fleet_obj['origin_g'] . ":" . $fleet_obj['origin_s'] . ":" . $fleet_obj['origin_p'] . "]"; $u = LoadUser($fleet_obj['owner_id']); echo " <br>" . AdminUserName($u); ?> </th> <th <?php echo $style; ?> > <?php echo "[" . $fleet_obj['target_g'] . ":" . $fleet_obj['target_s'] . ":" . $fleet_obj['target_p'] . "]"; $u = LoadUser($fleet_obj['target_id']); echo " <br>" . AdminUserName($u); ?> </th> <th <?php echo $style; ?> > <?php $fleetmap = array(202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215); foreach ($fleetmap as $i => $gid) { $amount = $fleet_obj["ship" . $gid]; if ($amount > 0) { echo loca("NAME_{$gid}") . ":" . nicenum($amount) . " "; } } ?> </th> <th <?php echo $style; ?> > <?php $total = $fleet_obj['pm'] + $fleet_obj['pk'] + $fleet_obj['pd']; if ($total > 0) { echo "М: " . nicenum($fleet_obj['pm']) . "<br>"; echo "К: " . nicenum($fleet_obj['pk']) . "<br>"; echo "Д: " . nicenum($fleet_obj['pd']); } else { echo "-"; } ?> </th> <th <?php echo $style; ?> > <?php $total = $fleet_obj['m'] + $fleet_obj['k'] + $fleet_obj['d']; if ($total > 0) { echo "М: " . nicenum($fleet_obj['m']) . "<br>"; echo "К: " . nicenum($fleet_obj['k']) . "<br>"; echo "Д: " . nicenum($fleet_obj['d']); } else { echo "-"; } ?> </th> <th <?php echo $style; ?> > <?php if ($fleet_obj['union_id']) { echo $fleet_obj['union_id']; } else { echo "-"; } ?> </th> </tr> <?php $bxx++; } echo "<script language=javascript>anz={$anz};t();</script>\n"; } else { ?> <tr><td class=c colspan=3>Логи полётов</td></tr> <tr><td>Задание</td><td>от <?php echo $user['oname']; ?> </td><td>на <?php echo $user['oname']; ?> </td></tr> <tr><td>Все</td><td><?php echo LinkFleetsFrom($user, 0); ?> </td><td><?php echo LinkFleetsTo($user, 0); ?> </td></tr> <tr><td>Атака</td><td><?php echo LinkFleetsFrom($user, 1); ?> </td><td><?php echo LinkFleetsTo($user, 1); ?> </td></tr> <tr><td>Совместная атака</td><td><?php echo LinkFleetsFrom($user, 2); ?> </td><td><?php echo LinkFleetsTo($user, 2); ?> </td></tr> <tr><td>Транспорт</td><td><?php echo LinkFleetsFrom($user, 3); ?> </td><td><?php echo LinkFleetsTo($user, 3); ?> </td></tr> <tr><td>Оставить</td><td><?php echo LinkFleetsFrom($user, 4); ?> </td><td><?php echo LinkFleetsTo($user, 4); ?> </td></tr> <tr><td>Держаться</td><td><?php echo LinkFleetsFrom($user, 5); ?> </td><td><?php echo LinkFleetsTo($user, 5); ?> </td></tr> <tr><td>Шпионаж</td><td><?php echo LinkFleetsFrom($user, 6); ?> </td><td><?php echo LinkFleetsTo($user, 6); ?> </td></tr> <tr><td>Колонизировать</td><td><?php echo LinkFleetsFrom($user, 7); ?> </td><td><?php echo LinkFleetsTo($user, 7); ?> </td></tr> <tr><td>Переработать</td><td><?php echo LinkFleetsFrom($user, 8); ?> </td><td><?php echo LinkFleetsTo($user, 8); ?> </td></tr> <tr><td>Уничтожить</td><td><?php echo LinkFleetsFrom($user, 9); ?> </td><td><?php echo LinkFleetsTo($user, 9); ?> </td></tr> <tr><td>Экспедиция</td><td><?php echo LinkFleetsFrom($user, 15); ?> </td><td><?php echo LinkFleetsTo($user, 15); ?> </td></tr> <tr><td>Ракетная атака</td><td><?php echo LinkFleetsFrom($user, 20); ?> </td><td><?php echo LinkFleetsTo($user, 20); ?> </td></tr> <tr><td>Атака (САБ)</td><td><?php echo LinkFleetsFrom($user, 21); ?> </td><td><?php echo LinkFleetsTo($user, 21); ?> </td></tr> </table> <?php } ?> <?php } else { $query = "SELECT * FROM " . $db_prefix . "users ORDER BY regdate DESC LIMIT 25"; $result = dbquery($query); AdminPanel(); echo " </th> \n"; echo " </tr> \n"; echo "</table> \n"; echo "Новые пользователи:<br>\n"; echo "<table>\n"; echo "<tr><td class=c>Дата регистрации</td><td class=c>Главная планета</td><td class=c>Имя игрока</td></tr>\n"; $rows = dbrows($result); while ($rows--) { $user = dbarray($result); $hplanet = GetPlanet($user['hplanetid']); echo "<tr><th>" . date("Y-m-d H:i:s", $user['regdate']) . "</th>"; echo "<th>[" . $hplanet['g'] . ":" . $hplanet['s'] . ":" . $hplanet['p'] . "] <a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $hplanet['planet_id'] . "\">" . $hplanet['name'] . "</a></th>"; echo "<th>" . AdminUserName($user) . "</th></tr>\n"; } echo "</table>\n"; ?> <br> <table> <?php $when = time() - 24 * 60 * 60; $query = "SELECT * FROM " . $db_prefix . "users WHERE lastclick >= {$when} ORDER BY oname ASC"; $result = dbquery($query); $rows = dbrows($result); ?> <tr><td class=c>Активные за последние 24 часа (<?php echo $rows; ?> )</td></tr> <tr><td> <?php $first = true; while ($rows--) { $user = dbarray($result); if ($first) { $first = false; } else { echo ", "; } echo AdminUserName($user); } ?> </td></tr> </table> <?php } // Поиск пользователей }
function Admin_Bans() { global $session; global $db_prefix; global $GlobalUser; // Обработка POST-запроса. if (method() === "POST" && $GlobalUser['admin'] >= 1) { if ($_GET['action'] === 'search') { // Результаты поиска switch (intval($_POST['searchby'])) { case 0: // Забаненных с РО $query = "SELECT * FROM " . $db_prefix . "users WHERE banned = 1 AND vacation = 1"; break; case 1: // Забаненных без РО $query = "SELECT * FROM " . $db_prefix . "users WHERE banned = 1 AND vacation = 0"; break; case 2: // Блокировка атак $query = "SELECT * FROM " . $db_prefix . "users WHERE noattack = 1"; break; case 3: // Зарегистрированных недавно (дней) $when = time() - intval($_POST['text']) * 24 * 60 * 60; $query = "SELECT * FROM " . $db_prefix . "users WHERE regdate >= {$when}"; break; case 4: // Имя пользователя (примерное) $query = "SELECT * FROM " . $db_prefix . "users WHERE oname LIKE '" . $_POST['text'] . "%' "; break; case 5: // Тег альянса $query = "SELECT ally_id FROM " . $db_prefix . "ally WHERE tag LIKE '%" . $_POST['text'] . "%' "; $query = "SELECT * FROM " . $db_prefix . "users WHERE ally_id = ANY ({$query}) "; break; case 6: // Одинаковый адрес email $query = "SELECT * FROM " . $db_prefix . "users WHERE email = LIKE '%" . $_POST['text'] . "%' OR pemail = LIKE '%" . $_POST['text'] . "%' "; break; case 7: // Одинаковый IP $query = "SELECT * FROM " . $db_prefix . "users AS t1 INNER JOIN ( \r\nSELECT ip_addr,COUNT(*) FROM " . $db_prefix . "users GROUP BY ip_addr HAVING COUNT(*)>1) as t2 \r\nON t1.ip_addr = t2.ip_addr ORDER BY t1.ip_addr ASC, t1.name ASC"; break; default: $query = ''; } $result = dbquery($query); $rows0 = $rows = dbrows($result); echo AdminPanel(); ?> <script> function SetClearCheckbox (status) { var theForm = document.getElementById('banform'); for (i=0,n=theForm.elements.length;i<n;i++) { if (theForm.elements[i].className.indexOf('ids') !=-1) { theForm.elements[i].checked = status; } } } </script> <!-- Результаты поиска --> <table> <form id="banform" action="index.php?page=admin&session=<?php echo $session; ?> &mode=Bans&action=ban" method="POST" > <tr> <td class=c> <input type="checkbox" onclick="SetClearCheckbox(this.checked);"> ID</td> <td class=c>Имя</td> <td class=c>Главная планета</td> <td class=c>Постоянный адрес</td> <td class=c>Временный адрес</td> <td class=c>IP адрес</td> <td class=c>Дата регистрации</td> </td> <?php if ($rows == 0) { echo "<tr><td colspan=7>Ничего не найдено. <a href=\"index.php?page=admin&session={$session}&mode=Bans\">Назад</a></td></tr>"; } while ($rows--) { $user = dbarray($result); $hp = GetPlanet($user['hplanetid']); ?> <tr> <th><input type="checkbox" name="id[<?php echo $user['player_id']; ?> ]" class="ids"/><?php echo $user['player_id']; ?> </th> <th><a><?php echo AdminUserName($user); ?> </a></th> <th><?php echo AdminPlanetCoord($hp); ?> <?php echo AdminPlanetName($hp); ?> </th> <th><a><?php echo $user['pemail']; ?> </a></th> <th><a><?php echo $user['email']; ?> </a></th> <th><?php echo $user['ip_addr']; ?> </th> <th><?php echo date("m-d-Y H:i:s", $user['regdate']); ?> </th> </tr> <?php } // while if ($rows0 > 0) { ?> <tr><td class=c colspan=7>Действия</td></tr> <tr> <td colspan=6> <input type="radio" name="banmode" value="0"> <font color=firebrick><b>Бан без РО</b></font> <input type="radio" name="banmode" value="1" checked > <font color=red><b>Бан с РО</b></font> <input type="radio" name="banmode" value="2"> <font color=yellow><b>Блок атак</b></font> <input type="radio" name="banmode" value="3"> <font color=lime><b>Разбанить</b></font> <input type="radio" name="banmode" value="4"> <font color=lime><b>Разрешить атаки</b></font> </td> <td><input name="days" type="text" size="5"> дней <input name="hours" type="text" size="3"> часов</td> </tr> <tr><th colspan=6> Причина: <textarea cols=40 rows=4 name="reason"><?php echo "[url=mailto:" . $GlobalUser['pemail'] . "]контакт[/url]"; ?> </textarea></th><th><input type="submit" value="Отправить"></th></tr> </form> </table> <?php } die; } if ($_GET['action'] === 'ban') { // Забанить / разбанить $now = time(); $reason = str_replace('\\"', """, bb($_POST['reason'])); $reason = str_replace('\'', "’", $reason); $reason = str_replace('\\`', "‘", $reason); $seconds = intval($_POST['days']) * 24 * 60 * 60 + intval($_POST['hours']) * 60 * 60; foreach ($_POST['id'] as $player_id => $checked) { $user = LoadUser($player_id); switch (intval($_POST['banmode'])) { case 0: // Добавить пользователя на столб позора $entry = array(null, $GlobalUser['oname'], $user['oname'], $GlobalUser['player_id'], $user['player_id'], $now, $now + $seconds, $reason); AddDBRow($entry, "pranger"); BanUser($player_id, $seconds, 0); break; case 1: // Добавить пользователя на столб позора $entry = array(null, $GlobalUser['oname'], $user['oname'], $GlobalUser['player_id'], $user['player_id'], $now, $now + $seconds, $reason); AddDBRow($entry, "pranger"); BanUser($player_id, $seconds, 1); break; case 2: // Добавить пользователя на столб позора $entry = array(null, $GlobalUser['oname'], $user['oname'], $GlobalUser['player_id'], $user['player_id'], $now, $now + $seconds, $reason); AddDBRow($entry, "pranger"); BanUserAttacks($player_id, $seconds); break; case 3: UnbanUser($player_id); break; case 4: UnbanUserAttacks($player_id); break; } } // for } } ?> <!-- Форма поиска --> <?php echo AdminPanel(); ?> <table> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Bans&action=search" method="POST" > <tr><td class="c" colspan=2>Найти пользователей</td></tr> <tr> <td> <select name="searchby"> <option value="0">Забаненных с РО</option> <option value="1">Забаненных без РО</option> <option value="2">Блокировка атак</option> <option value="3">Зарегистрированных недавно (дней)</option> <option value="4">Имя пользователя (примерное)</option> <option value="5">Тег альянса</option> <option value="6">Одинаковый адрес email</option> <option value="7">Одинаковый IP</option> </select> </td> <td> <input type="text" name="text" size=20></td> </tr> <tr><td class="c" colspan=2> <input type="submit" value="Отправить" /></td></tr> </form> </table> <?php }
function Admin_Debug() { global $session; global $db_prefix; global $GlobalUser; $message_limit = 50; if (key_exists('filter', $_REQUEST)) { $filter = $_REQUEST['filter']; } else { $filter = ""; } if (method() === "POST" && $filter === "") { if ($_POST['deletemessages'] === "deleteall") { $query = "TRUNCATE TABLE " . $db_prefix . "debug;"; dbquery($query); } else { $query = "SELECT * FROM " . $db_prefix . "debug ORDER BY date DESC, error_id DESC LIMIT " . $message_limit; $result = dbquery($query); $rows = dbrows($result); while ($rows--) { $msg = dbarray($result); if (key_exists("delmes" . $msg['error_id'], $_POST) || $_POST['deletemessages'] === "deleteshown") { $query = "DELETE FROM " . $db_prefix . "debug WHERE error_id = " . $msg['error_id']; dbquery($query); } } } } if ($filter === "") { $query = "SELECT * FROM " . $db_prefix . "debug ORDER BY date DESC, error_id DESC LIMIT " . $message_limit; } else { $query = "SELECT * FROM " . $db_prefix . "debug WHERE text LIKE '%" . $filter . "%' ORDER BY date DESC, error_id DESC LIMIT " . $message_limit; } $result = dbquery($query); ?> <?php echo AdminPanel(); ?> <table class='header'><tr class='header'><td><table width="519"> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Debug" method="POST"> <tr><td colspan="4" class="c">Сообщения</td></tr> <tr><th>Действие</th><th>Дата</th><th>От</th><th>Браузер</th></tr> <?php $rows = dbrows($result); while ($rows--) { $msg = dbarray($result); $user = LoadUser($msg['owner_id']); $from = "<a href=\"index.php?page=admin&session={$session}&mode=Users&player_id=" . $msg['owner_id'] . "\">" . $user['oname'] . "</a> [" . $msg['ip'] . "]"; $msg['text'] = str_replace("{PUBLIC_SESSION}", $session, $msg['text']); echo "<tr><th><input type=\"checkbox\" name=\"delmes" . $msg['error_id'] . "\"/></th><th>" . date("m-d H:i:s", $msg['date']) . "</th><th>{$from} </th><th>" . $msg['agent'] . " </th></tr>\n"; echo "<tr><td class=\"b\"> </td><td class=\"b\" colspan=\"3\">" . $msg['text'] . "</td></tr>\n"; } ?> <tr><td class="b"> </td><td class="b" colspan="3"></td></tr> <tr><th colspan="4" style='padding:0px 105px;'></th></tr> <tr> <th colspan="4"> <select name="deletemessages"> <option value="deletemarked">Удалить выделенные сообщения</option> <option value="deleteshown">Удалить показанные сообщения</option> <option value="deleteall">Удалить все сообщения</option> </select><input type="submit" value="ok" /></th></tr> <tr><td colspan="4"><center> </center></td></tr> <tr><th colspan="4">Фильтр отладочных сообщений: <input type=text name="filter" /> <input type=submit value="Показать"></th></tr> </form> </table> <?php }
function Admin_Broadcast() { global $session; global $db_prefix; global $GlobalUser; $write_error = ""; // Обработка POST-запроса. if (method() === "POST") { $cat = $_POST['cat']; $subj = $_POST['subj']; if ($subj === "") { $write_error = "<center><font color=#FF0000>Заполните тему</font><br/></center>\n"; } $text = $_POST['text']; if ($text === "") { $write_error = "<center><font color=#FF0000>Введите текст сообщения</font><br/></center>\n"; } if ($write_error === "") { if ($cat == 1) { $query = "SELECT * FROM " . $db_prefix . "users WHERE score1 < 5000;"; } else { if ($cat == 2) { $query = "SELECT * FROM " . $db_prefix . "users WHERE place1 < 100;"; } else { if ($cat == 3) { $query = "SELECT * FROM " . $db_prefix . "users WHERE admin = 1;"; } else { $query = "SELECT * FROM " . $db_prefix . "users;"; } } } // Всем $ownhome = GetPlanet($GlobalUser['hplanetid']); $from = $GlobalUser['oname'] . " <a href=\"index.php?page=galaxy&galaxy=" . $ownhome['g'] . "&system=" . $ownhome['s'] . "&position=" . $ownhome['p'] . "&session={PUBLIC_SESSION}\">[" . $ownhome['g'] . ":" . $ownhome['s'] . ":" . $ownhome['p'] . "]</a>\n"; $subj = $subj . " <a href=\"index.php?page=writemessages&session={PUBLIC_SESSION}&messageziel=" . $GlobalUser['player_id'] . "&re=1&betreff=Re:" . $subj . "\">\n" . "</a>\n"; $text = str_replace('\\"', """, bb($text)); $text = str_replace('\'', "’", $text); $text = str_replace('\\`', "‘", $text); $result = dbquery($query); $usernum = $rows = dbrows($result); while ($rows--) { $user = dbarray($result); SendMessage($user['player_id'], $from, $subj, $text, 5); } if ($usernum > 0) { $write_error = "<center><font color=#00FF00>Сообщение отправлено {$usernum} пользователям.</font><br/></center>\n"; } else { $write_error = "<center><font color=#00FF00>Адресаты не найдены.</font><br/></center>\n"; } } } ?> <?php echo AdminPanel(); ?> <?php echo $write_error; ?> <table> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Broadcast" method="POST"> <tr><td> Кому: <select name="cat"> <option value="0">Всем</option> <option value="1">Новичкам (менее 5.000 очков)</option> <option value="2">Игрокам из топ100</option> <option value="3">Операторам</option> </select> </td></tr> <tr><td> Тема : <input name="subj" size=80> </td></tr> <tr><td> <textarea cols='100' rows='20' name='text'></textarea> </td></tr> <tr><td> <center><input type="submit" value="Отправить"></center> </td></tr> </form> </table> <?php }
function Admin_Checksum() { global $session; global $db_prefix; global $GlobalUser; $engine_md = unserialize(file_get_contents('temp/engine.md5')); $page_md = unserialize(file_get_contents('temp/page.md5')); $reg_md = unserialize(file_get_contents('temp/reg.md5')); $engine_files = array('ainfo.php', 'ally.php', 'api.php', 'battle.php', 'battle_engine.php', 'bbcode.php', 'bot.php', 'botapi.php', 'cache.php', 'coupon.php', 'db.php', 'debug.php', 'expedition.php', 'fleet.php', 'galaxytool.php', 'index.php', 'install.php', 'loca.php', 'maintenance.php', 'msg.php', 'notes.php', 'page.php', 'pic.php', 'planet.php', 'pranger.php', 'prod.php', 'queue.php', 'redir.php', 'uni.php', 'unit.php', 'user.php', 'validate.php'); $page_files = array('pages/admin.php', 'pages/admin_bans.php', 'pages/admin_battle.php', 'pages/admin_botedit.php', 'pages/admin_bots.php', 'pages/admin_broadcast.php', 'pages/admin_browse.php', 'pages/admin_checksum.php', 'pages/admin_coupons.php', 'pages/admin_debug.php', 'pages/admin_errors.php', 'pages/admin_expedition.php', 'pages/admin_fleetlogs.php', 'pages/admin_logins.php', 'pages/admin_planets.php', 'pages/admin_queue.php', 'pages/admin_reports.php', 'pages/admin_sim.php', 'pages/admin_uni.php', 'pages/admin_userlogs.php', 'pages/admin_users.php', 'pages/ainfo.php', 'pages/allianzdepot.php', 'pages/allianzen.php', 'pages/allianzen_circular.php', 'pages/allianzen_main.php', 'pages/allianzen_members.php', 'pages/allianzen_misc.php', 'pages/allianzen_ranks.php', 'pages/allianzen_settings.php', 'pages/b_building.php', 'pages/bericht.php', 'pages/bewerben.php', 'pages/bewerbungen.php', 'pages/buddy.php', 'pages/buildings.php', 'pages/changelog.php', 'pages/fleet_templates.php', 'pages/flotten1.php', 'pages/flotten2.php', 'pages/flotten3.php', 'pages/flottenversand.php', 'pages/flottenversand_ajax.php', 'pages/galaxy.php', 'pages/imperium.php', 'pages/infos.php', 'pages/logout.php', 'pages/messages.php', 'pages/micropayment.php', 'pages/notizen.php', 'pages/options.php', 'pages/overview.php', 'pages/overview_events.php', 'pages/payment.php', 'pages/phalanx.php', 'pages/phalanx_events.php', 'pages/pranger.php', 'pages/renameplanet.php', 'pages/resources.php', 'pages/sprungtor.php', 'pages/statistics.php', 'pages/suche.php', 'pages/techtree.php', 'pages/techtreedetails.php', 'pages/trader.php', 'pages/writemessages.php'); $reg_files = array('reg/check_registration.php', 'reg/errorpage.php', 'reg/fa_pass.php', 'reg/login.php', 'reg/login2.php', 'reg/mail.php', 'reg/new.php', 'reg/newredirect.php'); if (method() === "POST") { // Сохранить контрольные суммы файлов foreach ($engine_files as $i => $filename) { $md = md5_file($filename); $engine_md[$filename] = $md; } foreach ($page_files as $i => $filename) { $md = md5_file($filename); $page_md[$filename] = $md; } foreach ($reg_files as $i => $filename) { $md = md5_file($filename); $reg_md[$filename] = $md; } file_put_contents('temp/engine.md5', serialize($engine_md)); file_put_contents('temp/page.md5', serialize($page_md)); file_put_contents('temp/reg.md5', serialize($reg_md)); } ?> <?php echo AdminPanel(); ?> <h2>Движок</h2> <table width="519"> <tr><td class=c>Путь к файлу</td><td class=c>Контрольная сумма</td><td class=c>Статус</td></tr> <?php foreach ($engine_files as $i => $filename) { $md = md5_file($filename); echo "<tr><td>{$filename}</td><td>{$md}</td>"; if (key_exists($filename, $engine_md)) { if ($engine_md[$filename] === $md) { echo "<td><font color=lime><b>OK</b></font></td>"; } else { echo "<td><font color=red><b>BAD</b></font></td>"; } } else { echo "<td><font color=red><b>UNVERSIONED</b></font></td>"; } echo "</tr>"; } ?> </table> <h2>Игровые страницы</h2> <table width="519"> <tr><td class=c>Путь к файлу</td><td class=c>Контрольная сумма</td><td class=c>Статус</td></tr> <?php foreach ($page_files as $i => $filename) { $md = md5_file($filename); echo "<tr><td>{$filename}</td><td>{$md}</td>"; if ($page_md[$filename] === $md) { echo "<td><font color=lime><b>OK</b></font></td>"; } else { echo "<td><font color=red><b>BAD</b></font></td>"; } echo "</tr>"; } ?> </table> <h2>Система регистрации</h2> <table width="519"> <tr><td class=c>Путь к файлу</td><td class=c>Контрольная сумма</td><td class=c>Статус</td></tr> <?php foreach ($reg_files as $i => $filename) { $md = md5_file($filename); echo "<tr><td>{$filename}</td><td>{$md}</td>"; if ($reg_md[$filename] === $md) { echo "<td><font color=lime><b>OK</b></font></td>"; } else { echo "<td><font color=red><b>BAD</b></font></td>"; } echo "</tr>"; } ?> </table> <br/> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Checksum" method="POST"> <input type=submit value="Зафиксировать контрольные суммы"> </form> <?php }
function Admin_Logins() { global $session; global $db_prefix; global $GlobalUser; AdminPanel(); // Обработка POST-запроса. if (method() === "POST") { if ($_POST['name'] !== '') { $searchtext = $_POST['name']; $query = "SELECT * FROM " . $db_prefix . "users WHERE oname LIKE '" . $searchtext . "%' LIMIT 25"; $result = dbquery($query); $rows = dbrows($result); echo "<table>"; while ($rows--) { $user = dbarray($result); $query = "SELECT * FROM " . $db_prefix . "iplogs WHERE user_id = '" . intval($user['player_id']) . "' AND reg = 0"; $result2 = dbquery($query); $rows2 = dbrows($result2); while ($rows2--) { $log = dbarray($result2); echo "<tr><td>"; echo date("Y-m-d H:i:s", $log['date']); echo " " . $log['ip']; echo " " . AdminUserName($user); echo "</td></tr>"; } } echo "</table>"; } if ($_POST['id'] !== '') { $query = "SELECT * FROM " . $db_prefix . "iplogs WHERE user_id = '" . intval($_POST['id']) . "' AND reg = 0"; $result = dbquery($query); $rows = dbrows($result); echo "<table>"; while ($rows--) { $log = dbarray($result); $user = LoadUser($log['user_id']); echo "<tr><td>"; echo date("Y-m-d H:i:s", $log['date']); echo " " . $log['ip']; echo " " . AdminUserName($user); echo "</td></tr>"; } echo "</table>"; } if ($_POST['ip'] !== '') { $query = "SELECT * FROM " . $db_prefix . "iplogs WHERE ip = '" . $_POST['ip'] . "' AND reg = 0"; $result = dbquery($query); $rows = dbrows($result); echo "<table>"; while ($rows--) { $log = dbarray($result); $user = LoadUser($log['user_id']); echo "<tr><td>"; echo date("Y-m-d H:i:s", $log['date']); echo " " . $log['ip']; echo " " . AdminUserName($user); echo "</td></tr>"; } echo "</table>"; } } ?> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Logins" method="POST"> <table> <tr> <td class=d>По имени пользователя:</td> <td> <input type=text size=20 name=name></td> </tr> <tr> <td class=d>По ID пользователя:</td> <td><input type=text size=20 name=id></td> </tr> <tr> <td class=d>По IP адресу:</td> <td> <input type=text size=20 name=ip></td> </tr> <tr> <td colspan=2 class=d><center><input type=submit value=Искать></center></td></tr> </table> </form> <?php }
function Admin_Planets() { global $loca_lang, $Languages; global $session; global $db_prefix; global $GlobalUser; $SearchResult = ""; $buildmap = array(1, 2, 3, 4, 12, 14, 15, 21, 22, 23, 24, 31, 33, 34, 41, 42, 43, 44); $fleetmap = array(202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215); $defmap = array(401, 402, 403, 404, 405, 406, 407, 408, 502, 503); // Обработка POST-запроса. if (method() === "POST" && $GlobalUser['admin'] >= 2) { $cp = intval($_GET['cp']); $action = $_GET['action']; $now = time(); //print_r ( $_POST); if ($action === "update") { $param = array('b1', 'b2', 'b3', 'b4', 'b12', 'b14', 'b15', 'b21', 'b22', 'b23', 'b24', 'b31', 'b33', 'b34', 'b41', 'b42', 'b43', 'b44', 'd401', 'd402', 'd403', 'd404', 'd405', 'd406', 'd407', 'd408', 'd502', 'd503', 'f202', 'f203', 'f204', 'f205', 'f206', 'f207', 'f208', 'f209', 'f210', 'f211', 'f212', 'f213', 'f214', 'f215', 'm', 'k', 'd', 'g', 's', 'p', 'diameter', 'type', 'temp', 'mprod', 'kprod', 'dprod', 'sprod', 'fprod', 'ssprod'); $moon_param = array('g', 's', 'p'); $query = "UPDATE " . $db_prefix . "planets SET lastpeek={$now}, "; foreach ($param as $i => $p) { if (strpos($p, "prod")) { $query .= ", {$p}='" . $_POST[$p] . "'"; } else { if ($i == 0) { $query .= "{$p}=" . intval($_POST[$p]); } else { $query .= ", {$p}=" . intval($_POST[$p]); } } } $query .= " WHERE planet_id={$cp};"; if (key_exists("delete_planet", $_POST)) { $planet = GetPlanet($cp); $user = LoadUser($planet['owner_id']); if ($user['hplanetid'] != $cp) { DestroyPlanet($cp); $_GET['cp'] = $user['hplanetid']; // перенаправить на главную планету. } } else { // Обновить данные планеты $moon_id = PlanetHasMoon($cp); // Переместить луну за планетой. if ($moon_id) { $mquery = "UPDATE " . $db_prefix . "planets SET lastpeek={$now}, "; foreach ($moon_param as $i => $p) { if ($i == 0) { $mquery .= "{$p}=" . intval($_POST[$p]); } else { $mquery .= ", {$p}=" . intval($_POST[$p]); } } $mquery .= " WHERE planet_id={$moon_id};"; dbquery($mquery); } dbquery($query); RecalcFields($cp); } } else { if ($action === "search") { $searchtype = $_POST['type']; if ($_POST['searchtext'] === "") { $SearchResult .= "Укажите строку для поиска<br>\n"; $searchtype = "none"; } if ($searchtype === "playername") { $query = "SELECT player_id FROM " . $db_prefix . "users WHERE oname LIKE '" . $_POST['searchtext'] . "%'"; $query = "SELECT * FROM " . $db_prefix . "planets WHERE owner_id = ANY ({$query});"; } else { if ($searchtype === "planetname") { $query = "SELECT * FROM " . $db_prefix . "planets WHERE name LIKE '" . $_POST['searchtext'] . "%';"; } else { if ($searchtype === "allytag") { $query = "SELECT ally_id FROM " . $db_prefix . "ally WHERE tag LIKE '" . $_POST['searchtext'] . "%'"; $query = "SELECT player_id FROM " . $db_prefix . "users WHERE ally_id <> 0 AND ally_id = ANY ({$query})"; $query = "SELECT * FROM " . $db_prefix . "planets WHERE owner_id = ANY ({$query});"; } } } if ($query) { $result = dbquery($query); } $SearchResult .= "<table>\n"; $rows = dbrows($result); if ($rows > 0) { while ($rows--) { $planet = dbarray($result); $user = LoadUser($planet['owner_id']); $SearchResult .= "<tr><th>" . date("Y-m-d H:i:s", $planet['date']) . "</th><th>" . AdminPlanetCoord($planet) . "</th>"; $SearchResult .= "<th><a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $planet['planet_id'] . "\">" . $planet['name'] . "</a></th>"; $SearchResult .= "<th><a href=\"index.php?page=admin&session={$session}&mode=Users&player_id=" . $user['player_id'] . "\">" . $user['oname'] . "</a></th></tr>\n"; } } else { $SearchResult .= "Ничего не найдено<br>\n"; } $SearchResult .= "</table>\n"; } } } // Обработка GET-запроса. if (method() === "GET" && $GlobalUser['admin'] >= 2) { if (key_exists('cp', $_GET)) { $cp = intval($_GET['cp']); } else { $cp = 0; } if (key_exists('action', $_GET) && $cp) { $action = $_GET['action']; } else { $action = ""; } $now = time(); if ($action === "create_moon") { $planet = GetPlanet($cp); if ($planet['type'] > 0 && $planet['type'] < 10000) { if (PlanetHasMoon($cp) == 0) { CreatePlanet($planet['g'], $planet['s'], $planet['p'], $planet['owner_id'], 0, 1, 20); } } } else { if ($action === "create_debris") { $planet = GetPlanet($cp); if ($planet['type'] > 0 && $planet['type'] < 10000) { if (HasDebris($planet['g'], $planet['s'], $planet['p']) == 0) { CreateDebris($planet['g'], $planet['s'], $planet['p'], $planet['owner_id']); } } } else { if ($action === "cooldown_gates") { $planet = GetPlanet($cp); if ($planet['type'] == 0) { $query = "UPDATE " . $db_prefix . "planets SET gate_until=0 WHERE planet_id=" . $planet['planet_id']; dbquery($query); } } else { if ($action === "warmup_gates") { $planet = GetPlanet($cp); if ($planet['type'] == 0) { $query = "UPDATE " . $db_prefix . "planets SET gate_until=" . ($now + 59 * 60 + 59) . " WHERE planet_id=" . $planet['planet_id']; dbquery($query); } } else { if ($action === "recalc_fields") { RecalcFields($cp); } else { if ($action === "random_diam") { $planet = GetPlanet($cp); if (GetPlanetType($planet) == 1) { $p = $planet['p']; if ($p <= 3) { $diam = mt_rand(50, 120) * 72; } else { if ($p >= 4 && $p <= 6) { $diam = mt_rand(50, 150) * 120; } else { if ($p >= 7 && $p <= 9) { $diam = mt_rand(50, 120) * 120; } else { if ($p >= 10 && $p <= 12) { $diam = mt_rand(50, 120) * 96; } else { if ($p >= 13 && $p <= 15) { $diam = mt_rand(50, 150) * 96; } } } } } $query = "UPDATE " . $db_prefix . "planets SET diameter={$diam} WHERE planet_id=" . $planet['planet_id']; dbquery($query); } } } } } } } } if (key_exists("cp", $_GET)) { // Информация о планете. $planet = GetPlanet(intval($_GET['cp'])); $user = LoadUser($planet['owner_id']); $moon_id = PlanetHasMoon($planet['planet_id']); $debris_id = HasDebris($planet['g'], $planet['s'], $planet['p']); $now = time(); // Парсер шпионских докладов. ?> <script> function php_str_replace(search, replace, subject) { // http://kevin.vanzonneveld.net var s = subject; var ra = r instanceof Array, sa = s instanceof Array; var f = [].concat(search); var r = [].concat(replace); var i = (s = [].concat(s)).length; var j = 0; while (j = 0, i--) { if (s[i]) { while (s[i] = (s[i]+'').split(f[j]).join(ra ? r[j] || '' : r[0]), ++j in f){}; } } return sa ? s : s[0]; } function spio () { global $GlobalUni; // // Перечислить все технологии для всех языков, а также ресурсы // var TechNames = { <?php foreach ($Languages as $lang => $langname) { loca_add("common", $lang); loca_add("technames", $lang); } $old_lang = $loca_lang; foreach ($Languages as $lang => $langname) { $loca_lang = $lang; foreach ($buildmap as $i => $gid) { echo "\"" . loca("NAME_{$gid}") . "\": {$gid}, "; } foreach ($fleetmap as $i => $gid) { echo "\"" . loca("NAME_{$gid}") . "\": {$gid}, "; } foreach ($defmap as $i => $gid) { echo "\"" . loca("NAME_{$gid}") . "\": {$gid}, "; } } ?> }; var ResNames = { <?php foreach ($Languages as $lang => $langname) { $loca_lang = $lang; echo "\"" . loca("METAL") . "\": 'm', "; echo "\"" . loca("CRYSTAL") . "\": 'k', "; echo "\"" . loca("DEUTERIUM") . "\": 'd', "; } $loca_lang = $old_lang; ?> }; var text = document.getElementById ("spiotext" ).value; text = php_str_replace (".", "", text); text = php_str_replace (":", "", text); for ( var name in TechNames ) { var id = TechNames[name]; pos = text.indexOf ( name ); if ( pos > 0 ) { obj = text.substr ( pos ); found = obj.match ("("+name+"[\\s]+)([0-9]{1,})"); document.getElementById ( "obj" + id ) . value = parseInt(found[2]); } } for ( var name in ResNames ) { var id = ResNames[name]; pos = text.indexOf ( name ); if ( pos > 0 ) { obj = text.substr ( pos ); found = obj.match ("("+name+"[\\s]+)([0-9]{1,})"); document.getElementById ( "obj" + id ) . value = parseInt(found[2]); } } } function reset () { var ids = [ <?php foreach ($buildmap as $i => $gid) { echo "{$gid}, "; } foreach ($fleetmap as $i => $gid) { echo "{$gid}, "; } foreach ($defmap as $i => $gid) { echo "{$gid}, "; } ?> ]; for ( var i in ids ) { document.getElementById ( "obj" + ids[i] ) . value = 0; } } </script> <?php AdminPanel(); echo "<table>\n"; echo "<form action=\"index.php?page=admin&session={$session}&mode=Planets&action=update&cp=" . $planet['planet_id'] . "\" method=\"POST\" >\n"; echo "<tr><td class=c colspan=2>Планета \"" . $planet['name'] . "\" (<a href=\"index.php?page=admin&session={$session}&mode=Users&player_id=" . $user['player_id'] . "\">" . $user['oname'] . "</a>)</td>\n"; echo " <td class=c >Постройки</td> <td class=c >Флот</td> <td class=c >Оборона</td> </tr>\n"; echo "<tr><th><img src=\"" . GetPlanetImage(UserSkin(), $planet) . "\"> <br>Тип: " . $planet['type']; $pp = PlanetPrice($planet); echo "<br>Стоимость : " . nicenum($pp['points'] / 1000); echo "<br>Постройки : " . nicenum(($pp['points'] - ($pp['fleet_pts'] + $pp['defense_pts'])) / 1000); echo "<br>Флот : " . nicenum($pp['fleet_pts'] / 1000); echo "<br>Оборона : " . nicenum($pp['defense_pts'] / 1000); if ($planet['type'] == 10000) { echo "<br>М: " . nicenum($planet['m']) . "<br>К: " . nicenum($planet['k']) . "<br>"; } echo "</th><th>"; if ($planet['type'] > 0 && $planet['type'] < 10000) { if ($moon_id) { $moon = GetPlanet($moon_id); echo "<a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $moon['planet_id'] . "\"><img src=\"" . GetPlanetSmallImage(UserSkin(), $moon) . "\"><br>\n"; echo $moon['name'] . "</a>"; } else { echo "<a href=\"index.php?page=admin&session={$session}&mode=Planets&action=create_moon&cp=" . $planet['planet_id'] . "\" >Создать луну</a>\n"; } echo "<br/><br/>\n"; if ($debris_id) { $debris = GetPlanet($debris_id); echo "<a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $debris['planet_id'] . "\"><img src=\"" . UserSkin() . "planeten/debris.jpg\"><br>\n"; echo $debris['name'] . "</a>"; echo "<br>М: " . nicenum($debris['m']) . "<br>К: " . nicenum($debris['k']) . "<br>"; } else { echo "<a href=\"index.php?page=admin&session={$session}&mode=Planets&action=create_debris&cp=" . $planet['planet_id'] . "\" >Создать поле обломков</a>\n"; } } else { $parent = LoadPlanet($planet['g'], $planet['s'], $planet['p'], 1); echo "<a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $parent['planet_id'] . "\"><img src=\"" . GetPlanetSmallImage(UserSkin(), $parent) . "\"><br>\n"; echo $parent['name'] . "</a>"; } ?> <br><br><textarea rows=10 cols=10 id="spiotext"></textarea> <a href="#" onclick="javascript:spio();">Разобрать данные доклада</a> <br> <a href="#" onclick="javascript:reset();">Сбросить</a> <?php echo "</th>"; echo "<th valign=top><table>\n"; foreach ($buildmap as $i => $gid) { echo "<tr><th>" . loca("NAME_{$gid}"); if ($gid == 43 && $planet['type'] == 0) { // управление воротами. if ($now >= $planet["gate_until"]) { // ворота готовы echo " <a href=\"index.php?page=admin&session={$session}&mode=Planets&action=warmup_gates&cp=" . $planet['planet_id'] . "\" >нагреть</a>"; } else { // ворота НЕ готовы $delta = $planet["gate_until"] - $now; echo " " . date('i\\m s\\s', $delta) . " <a href=\"index.php?page=admin&session={$session}&mode=Planets&action=cooldown_gates&cp=" . $planet['planet_id'] . "\">остудить</a>"; } } echo "</th><th><nobr><input id=\"obj{$gid}\" type=\"text\" size=3 name=\"b{$gid}\" value=\"" . $planet["b{$gid}"] . "\" />"; // управление шахтами и выработкой энергии. if ($gid == 1 && $planet['type'] != 0) { echo "<select name='mprod'>\n"; for ($prc = 0; $prc <= 1; $prc += 0.1) { echo "<option value='{$prc}' "; if ($planet["mprod"] == $prc . "") { echo " selected"; } echo ">" . $prc * 100 . "</option>\n"; } echo "</select>\n"; } if ($gid == 2 && $planet['type'] != 0) { echo "<select name='kprod'>\n"; for ($prc = 0; $prc <= 1; $prc += 0.1) { echo "<option value='{$prc}' "; if ($planet["kprod"] == $prc . "") { echo " selected"; } echo ">" . $prc * 100 . "</option>\n"; } echo "</select>\n"; } if ($gid == 3 && $planet['type'] != 0) { echo "<select name='dprod'>\n"; for ($prc = 0; $prc <= 1; $prc += 0.1) { echo "<option value='{$prc}' "; if ($planet["dprod"] == $prc . "") { echo " selected"; } echo ">" . $prc * 100 . "</option>\n"; } echo "</select>\n"; } if ($gid == 4 && $planet['type'] != 0) { echo "<select name='sprod'>\n"; for ($prc = 0; $prc <= 1; $prc += 0.1) { echo "<option value='{$prc}' "; if ($planet["sprod"] == $prc . "") { echo " selected"; } echo ">" . $prc * 100 . "</option>\n"; } echo "</select>\n"; } if ($gid == 12 && $planet['type'] != 0) { echo "<select name='fprod'>\n"; for ($prc = 0; $prc <= 1; $prc += 0.1) { echo "<option value='{$prc}' "; if ($planet["fprod"] == $prc . "") { echo " selected"; } echo ">" . $prc * 100 . "</option>\n"; } echo "</select>\n"; } echo "</nobr></th></tr>\n"; } echo "</table></th>\n"; echo "<th valign=top><table>\n"; foreach ($fleetmap as $i => $gid) { echo "<tr><th>" . loca("NAME_{$gid}") . "</th><th><nobr><input id=\"obj{$gid}\" type=\"text\" size=6 name=\"f{$gid}\" value=\"" . $planet["f{$gid}"] . "\" />"; if ($gid == 212 && $planet['type'] != 0) { echo "<select name='ssprod'>\n"; for ($prc = 0; $prc <= 1; $prc += 0.1) { echo "<option value='{$prc}' "; if ($planet["ssprod"] == $prc . "") { echo " selected"; } echo ">" . $prc * 100 . "</option>\n"; } echo "</select>\n"; } echo "</nobr></th></tr>\n"; } echo "</table></th>\n"; echo "<th valign=top><table>\n"; foreach ($defmap as $i => $gid) { echo "<tr><th>" . loca("NAME_{$gid}") . "</th><th><input id=\"obj{$gid}\" type=\"text\" size=6 name=\"d{$gid}\" value=\"" . $planet["d{$gid}"] . "\" /></th></tr>\n"; } echo "</table></th>\n"; echo "</tr>\n"; echo "<tr><th>Дата создания</th><th>" . date("Y-m-d H:i:s", $planet['date']) . "</th> <td colspan=10 class=c>Очередь построек</td></tr>"; echo "<tr><th>Дата удаления</th><th>" . date("Y-m-d H:i:s", $planet['remove']) . "</th> <th colspan=3 rowspan=12 valign=top style='text-align: left;'> "; $query = "SELECT * FROM " . $db_prefix . "buildqueue WHERE planet_id = " . $planet['planet_id'] . " ORDER BY list_id ASC"; $result = dbquery($query); $anz = dbrows($result); echo "<table>"; $bxx = 1; $duration = 0; while ($row = dbarray($result)) { echo "<tr><td> <table><tr><th><div id='bxx" . $bxx . "' title='" . ($row['end'] - $row['start'] - ($now - ($row['start'] + $duration))) . "' star='" . $duration . "'></th>"; echo "<tr><th>" . date("d.m.Y H:i:s", $row['end'] + $duration) . "</th></tr></table></td>"; echo "<td><img width='32px' src='" . UserSkin() . "gebaeude/" . $row['tech_id'] . ".gif'></td>"; echo "<td><b>" . loca("NAME_" . $row['tech_id']) . "</b><br>уровень " . $row['level'] . "</td></tr>"; $bxx++; $duration += $row['end'] - $row['start']; } echo "</table>"; echo "<script language=javascript>anz={$anz};t();</script>\n"; ?> <?php echo "</th> </tr>"; echo "<tr><th>Последняя активность</th><th>" . date("Y-m-d H:i:s", $planet['lastakt']) . "</th> \n"; echo "<input type=\"hidden\" name=\"type\" value=\"" . $planet['type'] . "\" >\n"; echo "</th> </tr>\n"; echo "<tr><th>Последнее обновление</th><th>" . date("Y-m-d H:i:s", $planet['lastpeek']) . "</th></tr>\n"; echo "<tr><th>Диаметр <br><a href=\"index.php?page=admin&session={$session}&mode=Planets&action=random_diam&cp=" . $planet['planet_id'] . "\" >новый диаметр</a> </th><th><input size=5 type=\"text\" name=\"diameter\" value=\"" . $planet['diameter'] . "\" /> км (" . $planet['fields'] . " из " . $planet['maxfields'] . " полей) "; echo "<a href=\"index.php?page=admin&session={$session}&mode=Planets&action=recalc_fields&cp=" . $planet['planet_id'] . "\" >пересчитать поля</a> "; echo "</th></tr>\n"; echo "<tr><th>Температура</th><th>от <input size=5 type=\"text\" name=\"temp\" value=\"" . $planet['temp'] . "\" />°C до " . ($planet['temp'] + 40) . "°C</th></tr>\n"; echo "<tr><th>Координаты</th><th>[<input type=\"text\" name=\"g\" value=\"" . $planet['g'] . "\" size=1 />:<input type=\"text\" name=\"s\" value=\"" . $planet['s'] . "\" size=2 />:<input type=\"text\" name=\"p\" value=\"" . $planet['p'] . "\" size=1 />]</th></tr>\n"; echo "<tr><td class=c colspan=2>Ресурсы</td></tr>\n"; echo "<tr><th>Металл</th><th><input id=\"objm\" type=\"text\" name=\"m\" value=\"" . ceil($planet['m']) . "\" /></th></tr>\n"; echo "<tr><th>Кристалл</th><th><input id=\"objk\" type=\"text\" name=\"k\" value=\"" . ceil($planet['k']) . "\" /></th></tr>\n"; echo "<tr><th>Дейтерий</th><th><input id=\"objd\" type=\"text\" name=\"d\" value=\"" . ceil($planet['d']) . "\" /></th></tr>\n"; echo "<tr><th>Энергия</th><th>" . $planet['e'] . " / " . $planet['emax'] . "</th></tr>\n"; echo "<tr><th>Коэффициент производства</th><th>" . $planet['factor'] . "</th></tr>\n"; echo "<tr><th colspan=8><input type=\"submit\" value=\"Сохранить\" /> <input type=\"submit\" name=\"delete_planet\" value=\"Удалить\" /> </th></tr>\n"; echo "</form>\n"; echo "</table>\n"; } else { $query = "SELECT * FROM " . $db_prefix . "planets ORDER BY date DESC LIMIT 25"; $result = dbquery($query); AdminPanel(); echo " </th> \n"; echo " </tr> \n"; echo "</table> \n"; echo "Новые планеты:<br>\n"; echo "<table>\n"; echo "<tr><td class=c>Дата создания</td><td class=c>Координаты</td><td class=c>Планета</td><td class=c>Игрок</td></tr>\n"; $rows = dbrows($result); while ($rows--) { $planet = dbarray($result); $user = LoadUser($planet['owner_id']); echo "<tr><th>" . date("Y-m-d H:i:s", $planet['date']) . "</th><th>" . AdminPlanetCoord($planet) . "</th>"; echo "<th><a href=\"index.php?page=admin&session={$session}&mode=Planets&cp=" . $planet['planet_id'] . "\">" . $planet['name'] . "</a></th>"; echo "<th>" . AdminUserName($user) . "</th></tr>\n"; } echo "</table>\n"; ?> </th> </tr> </table> Искать:<br> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Planets&action=search" method="post"> <table> <tr> <th> <select name="type"> <option value="playername">Имя игрока</option> <option value="planetname" >Имя планеты</option> <option value="allytag" >Аббревиатура альянса</option> </select> <input type="text" name="searchtext" value=""/> <input type="submit" value="Искать" /> </th> </tr> </table> </form> <?php if ($SearchResult !== "") { ?> </th> </tr> </table> Результаты поиска:<br> <?php echo $SearchResult; } } }
function Admin_Fleetlogs() { global $session; global $db_prefix; global $GlobalUser; $now = time(); // Обработка POST-запросов. $player_id = 0; if (method() === "POST" && $GlobalUser['admin'] >= 2) { if (key_exists("order_2min", $_POST)) { // -2 минуты до оконачания задания $id = intval($_POST['order_2min']); $queue = LoadQueue($id); $fleet_obj = LoadFleet($queue['sub_id']); if ($fleet_obj['union_id']) { UpdateUnionTime($fleet_obj['union_id'], $now + 2 * 60, 0, true); } else { $query = "UPDATE " . $db_prefix . "queue SET end=" . ($now + 2 * 60) . " WHERE task_id={$id}"; dbquery($query); } } if (key_exists("order_end", $_POST)) { // Завершить задание $id = intval($_POST['order_end']); $queue = LoadQueue($id); $fleet_obj = LoadFleet($queue['sub_id']); if ($fleet_obj['union_id']) { UpdateUnionTime($fleet_obj['union_id'], $now, 0, true); } else { $query = "UPDATE " . $db_prefix . "queue SET end={$now} WHERE task_id={$id}"; dbquery($query); } } if (key_exists("order_return", $_POST)) { // Развернуть флот $queue = LoadQueue(intval($_POST['order_return'])); RecallFleet($queue['sub_id']); } } $query = "SELECT * FROM " . $db_prefix . "queue WHERE type='Fleet' ORDER BY end ASC"; $result = dbquery($query); $anz = $rows = dbrows($result); $bxx = 1; AdminPanel(); echo "<table>\n"; echo "<tr><td class=c>N</td> <td class=c>Таймер</td> <td class=c>Задание</td> <td class=c>Отправлен</td> <td class=c>Прибывает</td><td class=c>Время полёта</td> <td class=c>Старт</td> <td class=c>Цель</td> <td class=c>Флот</td> <td class=c>Груз</td> <td class=c>Топливо</td> <td class=c>САБ</td> <td class=c colspan=3>Приказ</td> </tr>\n"; while ($rows--) { $queue = dbarray($result); $fleet_obj = LoadFleet($queue['sub_id']); $fleet_price = FleetPrice($fleet_obj); $points = $fleet_price['points']; $fpoints = $fleet_price['fpoints']; $style = ""; if ($points >= 100000000) { if ($fleet_obj['mission'] <= 2) { $style = " style=\"background-color: FireBrick;\" "; } else { $style = " style=\"background-color: DarkGreen;\" "; } } ?> <tr <?php echo $style; ?> > <th <?php echo $style; ?> > <?php echo $bxx; ?> </th> <th <?php echo $style; ?> > <?php echo "<table><tr {$style} ><th {$style} ><div id='bxx" . $bxx . "' title='" . ($queue['end'] - $now) . "' star='" . $queue['start'] . "'> </th>"; echo "<tr><th {$style} >" . date("d.m.Y H:i:s", $queue['end']) . "</th></tr></table>"; ?> </th> <th <?php echo $style; ?> > <?php echo FleetlogsMissionText($fleet_obj['mission']); ?> </th> <th <?php echo $style; ?> ><?php echo date("d.m.Y", $queue['start']); ?> <br> <?php echo date("H:i:s", $queue['start']); ?> </th> <th <?php echo $style; ?> ><?php echo date("d.m.Y", $queue['end']); ?> <br> <?php echo date("H:i:s", $queue['end']); ?> </th> <th <?php echo $style; ?> > <?php echo "<nobr>" . BuildDurationFormat($fleet_obj['flight_time']) . "</nobr><br>"; echo "<nobr>" . $fleet_obj['flight_time'] . " сек.</nobr>"; ?> </th> <th <?php echo $style; ?> > <?php $planet = GetPlanet($fleet_obj['start_planet']); $user = LoadUser($planet['owner_id']); echo AdminPlanetName($planet) . " " . AdminPlanetCoord($planet) . " <br>"; echo AdminUserName($user); ?> </th> <th <?php echo $style; ?> > <?php $planet = GetPlanet($fleet_obj['target_planet']); $user = LoadUser($planet['owner_id']); echo AdminPlanetName($planet) . " " . AdminPlanetCoord($planet) . " <br>"; echo AdminUserName($user); ?> </th> <th <?php echo $style; ?> > <?php $fleetmap = array(202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215); foreach ($fleetmap as $i => $gid) { $amount = $fleet_obj["ship" . $gid]; if ($amount > 0) { echo loca("NAME_{$gid}") . ":" . nicenum($amount) . " "; } } ?> </th> <th <?php echo $style; ?> > <?php $total = $fleet_obj['m'] + $fleet_obj['k'] + $fleet_obj['d']; if ($total > 0) { echo "М: " . nicenum($fleet_obj['m']) . "<br>"; echo "К: " . nicenum($fleet_obj['k']) . "<br>"; echo "Д: " . nicenum($fleet_obj['d']); } else { echo "-"; } ?> </th> <th <?php echo $style; ?> > <?php echo nicenum($fleet_obj['fuel']); ?> </th> <th <?php echo $style; ?> > <?php if ($fleet_obj['union_id']) { echo $fleet_obj['union_id']; } else { echo "-"; } ?> </th> <th <?php echo $style; ?> > <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Fleetlogs" method="POST"> <input type="hidden" name="order_2min" value="<?php echo $queue['task_id']; ?> " /> <input type="submit" value="2m" /> </form> </th> <th <?php echo $style; ?> > <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Fleetlogs" method="POST"> <input type="hidden" name="order_end" value="<?php echo $queue['task_id']; ?> " /> <input type="submit" value="F" /> </form> </th><th <?php echo $style; ?> > <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Fleetlogs" method="POST"> <input type="hidden" name="order_return" value="<?php echo $queue['task_id']; ?> " /> <input type="submit" value="R" /> </form> </th> </tr> <?php $bxx++; } echo "<script language=javascript>anz={$anz};t();</script>\n"; echo "</table>\n"; }
function Admin_Queue() { global $session; global $db_prefix; global $GlobalUser; // Обработка POST-запросов. $player_id = 0; if (method() === "POST") { if (key_exists("player", $_POST)) { // Фильтр по имени игрока $query = "SELECT * FROM " . $db_prefix . "users WHERE oname LIKE '" . $_POST['player'] . "%'"; $result = dbquery($query); if (dbrows($result) > 0) { $user = dbarray($result); $player_id = $user['player_id']; } } if (key_exists("order_end", $_POST) && $GlobalUser['admin'] >= 2) { // Завершить задание $id = intval($_POST['order_end']); $now = time(); $query = "UPDATE " . $db_prefix . "queue SET end={$now} WHERE task_id={$id}"; dbquery($query); } if (key_exists("order_remove", $_POST) && $GlobalUser['admin'] >= 2) { // Удалить задание RemoveQueue(intval($_POST['order_remove'])); } } if ($player_id > 0) { $query = "SELECT * FROM " . $db_prefix . "queue WHERE (type <> 'Fleet' AND type <> 'CommanderOff') AND owner_id={$player_id} ORDER BY end ASC, prio DESC"; } else { $query = "SELECT * FROM " . $db_prefix . "queue WHERE (type <> 'Fleet' AND type <> 'CommanderOff') ORDER BY end ASC, prio DESC LIMIT 50"; } $result = dbquery($query); $now = time(); AdminPanel(); echo "<table>\n"; echo "<tr><td class=c>Время окончания</td><td class=c>Игрок</td><td class=c>Тип задания</td><td class=c>Описание</td><td class=c>Приоритет</td><td class=c>ID</td><td class=c>Управление</td></tr>\n"; $anz = $rows = dbrows($result); $bxx = 1; while ($rows--) { $queue = dbarray($result); $user = LoadUser($queue['owner_id']); $pid = $user['player_id']; echo "<tr><th> <table><tr><th><div id='bxx" . $bxx . "' title='" . ($queue['end'] - $now) . "' star='" . $queue['start'] . "'></th>"; echo "<tr><th>" . date("d.m.Y H:i:s", $queue['end']) . "</th></tr></table></th><th><a href=\"index.php?page=admin&session={$session}&mode=Users&player_id={$pid}\">" . $user['oname'] . "</a></th><th>" . $queue['type'] . "</th><th>" . QueueDesc($queue) . "</th><th>" . $queue['prio'] . "</th><th>" . $queue['task_id'] . "</th>\n"; ?> <th> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Queue" method="POST"> <input type="hidden" name="order_end" value="<?php echo $queue['task_id']; ?> " /> <input type="submit" value="Завершить" /> </form> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Queue" method="POST" style="border: 1px solid red"> <input type="hidden" name="order_remove" value="<?php echo $queue['task_id']; ?> " /> <input type="submit" value="Удалить" /> </form> </th> </tr> <?php $bxx++; } echo "<script language=javascript>anz={$anz};t();</script>\n"; echo "</table>\n"; $playername = ""; if ($player_id > 0) { $user = LoadUser($player_id); $playername = $user['name']; } ?> <br/> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Queue" method="POST"> Показать задания игрока : <input size=15 name="player" value="<?php echo $playername; ?> "> <input type="submit" value="Отправить"> </form> <?php }
function Admin_BattleSim() { global $session; global $db_prefix; global $GlobalUser; $fleetmap = array(202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215); $defmap = array(401, 402, 403, 404, 405, 406, 407, 408); $unitab = LoadUniverse(); $rf = $unitab['rapid']; $fid = $unitab['fid']; $did = $unitab['did']; $debug = false; $maxslot = $unitab['acs'] * $unitab['acs']; $BattleReport = ""; $aloss = $dloss = 0; // -------------------------------------------------------------------------------------------------------------------------- // Обработка POST-запроса. if (method() === "POST" && $GlobalUser['admin'] >= 2) { //print_r ( $_POST ); //echo "<hr>"; // Сформировать список атакующих и обороняющихся $a = array(); $d = array(); $anum = intval($_POST['anum']); $dnum = intval($_POST['dnum']); // Атакующие for ($i = 0; $i < $anum; $i++) { if ($_POST["a" . $i . "_weap"] === "") { $_POST["a" . $i . "_weap"] = 0; } if ($_POST["a" . $i . "_shld"] === "") { $_POST["a" . $i . "_shld"] = 0; } if ($_POST["a" . $i . "_armor"] === "") { $_POST["a" . $i . "_armor"] = 0; } $a[$i]['r109'] = intval($_POST["a" . $i . "_weap"]); $a[$i]['r110'] = intval($_POST["a" . $i . "_shld"]); $a[$i]['r111'] = intval($_POST["a" . $i . "_armor"]); $a[$i]['oname'] = "Attacker{$i}"; $a[$i]['g'] = mt_rand(1, 9); $a[$i]['s'] = mt_rand(1, 499); $a[$i]['p'] = mt_rand(1, 15); $a[$i]['fleet'] = array(); foreach ($fleetmap as $n => $gid) { if ($_POST["a" . $i . "_{$gid}"] === "") { $_POST["a" . $i . "_{$gid}"] = 0; } $a[$i]['fleet'][$gid] = intval($_POST["a" . $i . "_{$gid}"]); } } // Обороняющиеся for ($i = 0; $i < $dnum; $i++) { if ($_POST["d" . $i . "_weap"] === "") { $_POST["d" . $i . "_weap"] = 0; } if ($_POST["d" . $i . "_shld"] === "") { $_POST["d" . $i . "_shld"] = 0; } if ($_POST["d" . $i . "_armor"] === "") { $_POST["d" . $i . "_armor"] = 0; } $d[$i]['r109'] = intval($_POST["d" . $i . "_weap"]); $d[$i]['r110'] = intval($_POST["d" . $i . "_shld"]); $d[$i]['r111'] = intval($_POST["d" . $i . "_armor"]); $d[$i]['oname'] = "Defender{$i}"; $d[$i]['g'] = mt_rand(1, 9); $d[$i]['s'] = mt_rand(1, 499); $d[$i]['p'] = mt_rand(1, 15); $d[$i]['fleet'] = array(); foreach ($fleetmap as $n => $gid) { if ($_POST["d" . $i . "_{$gid}"] === "") { $_POST["d" . $i . "_{$gid}"] = 0; } $d[$i]['fleet'][$gid] = intval($_POST["d" . $i . "_{$gid}"]); } $d[$i]['defense'] = array(); foreach ($defmap as $n => $gid) { if ($_POST["d" . $i . "_{$gid}"] === "") { $_POST["d" . $i . "_{$gid}"] = 0; } $d[$i]['defense'][$gid] = intval($_POST["d" . $i . "_{$gid}"]); } } // Симулировать битву $battle_result = 0; if ($_POST['debug'] === "on") { $debug = true; } else { $debug = false; } if ($_POST['rapid'] === "on") { $rf = true; } else { $rf = 0; } if ($_POST['fid'] === "") { $fid = 0; } else { $fid = intval($_POST['fid']); } if ($_POST['did'] === "") { $did = 0; } else { $did = intval($_POST['did']); } $BattleReport = SimBattle($a, $d, $rf, $fid, $did, $debug, &$battle_result, &$aloss, &$dloss); } // -------------------------------------------------------------------------------------------------------------------------- // Таблица ввода параметров симуляции. function getval($name) { if ($_POST[$name] != "") { return "value=\"" . $_POST[$name] . "\" "; } } function getval2($arr, $id) { if ($_POST[$arr][$id] != 0) { return "value=\"" . $_POST[$arr][$id] . "\" "; } else { return ""; } } ?> <script language="JavaScript"> var maxslot = <?php echo $maxslot; ?> ; function toint (num) { if ( typeof (num) == "undefined" ) num = 0; return parseInt (num); } // Пересчитать количество атакующих и обороняющихся. function RecalcAttackersDefendersNum () { var anum = dnum = 1; var fleet = [ 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215 ]; var defense = [ 401, 402, 403, 404, 405, 406, 407, 408 ]; for ( n=0; n<maxslot; n++ ) // Атакующие { sum = 0; for (var i in fleet) { value = toint (document.getElementById ( "a"+n+"_" + fleet[i] ).value); if ( value ) sum += value; } if ( sum > 0 ) anum = n + 1; } for ( n=0; n<maxslot; n++ ) // Обороняющиеся { sum = 0; for (var i in fleet) { value = toint (document.getElementById ( "d"+n+"_" + fleet[i] ).value); if ( value ) sum += value; } for (var i in defense) { value = toint (document.getElementById ( "d"+n+"_" + defense[i] ).value); if ( value ) sum += value; } if ( sum > 0 ) dnum = n + 1; } document.getElementById ( "anum" ).value = anum; document.getElementById ( "dnum" ).value = dnum; //alert ( "Атакующих : " + anum + ", Обороняющихся : " + dnum ); } // При смене слота - занести данные из массива слотов в ячейки ввода function OnChangeSlot (attacker) { var fleet = [ 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215 ]; var defense = [ 401, 402, 403, 404, 405, 406, 407, 408 ]; if (attacker) { slot = document.simForm.aslot.value - 1; for (var i in fleet) { value = toint (document.getElementById ( "a"+slot+"_" + fleet[i] ).value); if (value) document.getElementById ( "a_" + fleet[i] ).value = value; else document.getElementById ( "a_" + fleet[i] ).value = ""; } } else { slot = document.simForm.dslot.value - 1; for (var i in fleet) { value = toint (document.getElementById ( "d"+slot+"_" + fleet[i] ).value); if ( value ) document.getElementById ( "d_" + fleet[i] ).value = value; else document.getElementById ( "d_" + fleet[i] ).value = ""; } for (var i in defense) { value = toint (document.getElementById ( "d"+slot+"_" + defense[i] ).value); if (value) document.getElementById ( "d_" + defense[i] ).value = value; else document.getElementById ( "d_" + defense[i] ).value = ""; } } } // При изменении ячейки - внести данные из неё в массив слотов function OnChangeValue (attacker, id) { if (attacker) { slot = document.simForm.aslot.value - 1; document.getElementById ( "a"+slot+"_" + id ).value = document.getElementById ( "a_" + id ).value; } else { slot = document.simForm.dslot.value - 1; document.getElementById ( "d"+slot+"_" + id ).value = document.getElementById ( "d_" + id ).value; } RecalcAttackersDefendersNum (); } RecalcAttackersDefendersNum (); </script> <?php echo AdminPanel(); ?> <table cellpadding=0 cellspacing=0> <form name="simForm" action="index.php?page=admin&session=<?php echo $session; ?> &mode=BattleSim" method="POST" > <?php for ($n = 0; $n < $maxslot; $n++) { foreach ($fleetmap as $i => $gid) { echo "<input type=\"hidden\" id=\"a" . $n . "_{$gid}\" name=\"a" . $n . "_{$gid}\" value=\"0\"> \n"; } foreach ($fleetmap as $i => $gid) { echo "<input type=\"hidden\" id=\"d" . $n . "_{$gid}\" name=\"d" . $n . "_{$gid}\" value=\"0\"> \n"; } foreach ($defmap as $i => $gid) { echo "<input type=\"hidden\" id=\"d" . $n . "_{$gid}\" name=\"d" . $n . "_{$gid}\" value=\"0\"> \n"; } echo "<input type=\"hidden\" id=\"a" . $n . "_weap\" name=\"a" . $n . "_weap\" size=2 > <input type=\"hidden\" id=\"a" . $n . "_shld\" name=\"a" . $n . "_shld\" size=2 > <input type=\"hidden\" id=\"a" . $n . "_armor\" name=\"a" . $n . "_armor\" size=2 > \n"; echo "<input type=\"hidden\" id=\"d" . $n . "_weap\" name=\"d" . $n . "_weap\" size=2 > <input type=\"hidden\" id=\"d" . $n . "_shld\" name=\"d" . $n . "_shld\" size=2 > <input type=\"hidden\" id=\"d" . $n . "_armor\" name=\"d" . $n . "_armor\" size=2 > \n"; } ?> <input type="hidden" id="anum" name="anum" value="1" /> <input type="hidden" id="anum" name="dnum" value="1" /> <tr> <td class=c>Атакующий</td> <td class=c>Оборояющийся</td> </tr> <tr> <td> Вооружение: <input id="a_weap" size=2 > Щиты: <input id="a_shld" size=2 > Броня: <input id="a_armor" size=2 ></td> <td> Вооружение: <input id="d_weap" size=2 > Щиты: <input id="d_shld" size=2 > Броня: <input id="d_armor" size=2 ></td> </tr> <tr> <th valign=top> <table> <?php echo "<tr><td class=c><b>Флот</b></td> "; if ($maxslot > 0) { echo "<td>Слот: <select name=\"aslot\" onchange=\"OnChangeSlot(1);\">\n"; for ($n = 1; $n <= $maxslot; $n++) { echo "<option value=\"{$n}\">{$n}</option>\n"; } echo "</select> </td> "; } echo " </tr>\n"; foreach ($fleetmap as $i => $gid) { ?> <tr><td> <?php echo loca("NAME_{$gid}"); ?> </td> <td> <input id="a_<?php echo $gid; ?> " size=5 onKeyUp="OnChangeValue(1, <?php echo $gid; ?> );"> </td> </tr> <?php } ?> <tr><td colspan=2> <table> <tr><td class=c colspan=2>Настройки</td></tr> <tr><td>Отладочная информация</td><td><input type="checkbox" name="debug" <? if($debug) echo "checked"; ?> ></td></tr> <tr><td>Скорострел</td><td><input type="checkbox" name="rapid" <? if($rf) echo "checked"; ?> ></td></tr> <tr><td>Флот в обломки</td><td><input name="fid" size=3 value="<?php echo $fid; ?> "> </td></tr> <tr><td>Оборона в обломки</td><td><input name="did" size=3 value="<?php echo $did; ?> "></td></tr> </table> </td></tr> </table> </th> <th valign=top> <table> <?php echo "<tr><td class=c><b>Флот</b></td>"; if ($maxslot > 0) { echo "<td>Слот: <select name=\"dslot\" onchange=\"OnChangeSlot(0);\">\n"; for ($n = 1; $n <= $maxslot; $n++) { echo "<option value=\"{$n}\">{$n}</option>\n"; } echo "</select> </td> "; } echo "</tr>\n"; foreach ($fleetmap as $i => $gid) { ?> <tr><td> <?php echo loca("NAME_{$gid}"); ?> </td> <td> <input id="d_<?php echo $gid; ?> " size=5 onKeyUp="OnChangeValue(0, <?php echo $gid; ?> );"> </td> </tr> <?php } echo "<tr><td class=c><b>Оборона</b></td></tr>\n"; foreach ($defmap as $i => $gid) { ?> <tr><td> <?php echo loca("NAME_{$gid}"); ?> </td> <td> <input id="d_<?php echo $gid; ?> " size=5 onKeyUp="OnChangeValue(0, <?php echo $gid; ?> );"> </td> </tr> <?php } ?> </table> </th></tr> <tr><td colspan=2><center><input type="submit" value="Начать бой"></center></td></tr> </form> </table> <?php if ($BattleReport !== "") { $a_result = array(0 => "combatreport_ididattack_iwon", 1 => "combatreport_ididattack_ilost", 2 => "combatreport_ididattack_draw"); $bericht = SendMessage($GlobalUser['player_id'], "Командование флотом", "Боевой доклад", $BattleReport, 6); MarkMessage($GlobalUser['player_id'], $bericht); $subj = "<a href=\"#\" onclick=\"fenster('index.php?page=bericht&session={$session}&bericht={$bericht}', 'Bericht_Kampf');\" ><span class=\"" . $a_result[$battle_result] . "\">Боевой доклад [" . $d[0]['g'] . ":" . $d[0]['s'] . ":" . $d[0]['p'] . "] (V:" . nicenum($dloss) . ",A:" . nicenum($aloss) . ")</span></a>"; echo "{$subj}<br>"; } ?> <?php }
function Admin_Bots() { global $session; global $db_prefix; global $GlobalUser; $result = ""; // Обработка POST-запроса. if (method() === "POST") { if (AddBot($_POST['name'])) { $result = "<font color=lime>Бот успешно добавлен.</font>"; } else { $result = "<font color=red>Игрок с таким именем уже существует.</font>"; } } // Обработка GET-запроса. if (method() === "GET") { StopBot(intval($_GET['id'])); $result = "<font color=lime>Бот остановлен.</font>"; } ?> <?php echo AdminPanel(); ?> <center><?php echo $result; ?> </center> <h2>Список ботов:</h2> <?php $query = "SELECT * FROM " . $db_prefix . "queue WHERE type = 'AI' GROUP BY owner_id"; $result = dbquery($query); $rowss = $rows = dbrows($result); if ($rows == 0) { echo "Ботов не обнаружено<br>"; } else { echo "<table>\n"; echo "<tr><td class=c>ID</td><td class=c>Имя</td><td class=c>Главная планета</td><td class=c>Действие</td></tr>\n"; } while ($rows--) { $queue = dbarray($result); $user = LoadUser($queue['owner_id']); $planet = GetPlanet($user['hplanetid']); echo "<tr>"; echo "<td>" . $user['player_id'] . "</td>"; echo "<td>" . AdminUserName($user) . "</td>"; echo "<td>" . AdminPlanetName($planet) . " " . AdminPlanetCoord($planet) . "</td>"; echo "<td><a href=\"index.php?page=admin&session={$session}&mode=Bots&action=stop&id=" . $user['player_id'] . "\">Остановить</a></td>"; echo "</tr>\n"; } if ($rowss) { echo "</table>"; } ?> <h2>Добавить бота:</h2> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Bots" method="POST"> <table> <tr><td>Имя <input type=text size=10 name="name" /> <input type=submit value="Отправить" /></td></tr> </table> </form> <?php }
function Admin_BattleReport() { global $session; global $db_prefix; global $GlobalUser; ?> <?php echo AdminPanel(); ?> <?php // Показать боевой доклад if (key_exists('bericht', $_GET)) { $query = "SELECT * FROM " . $db_prefix . "battledata WHERE battle_id = " . intval($_GET['bericht']); $result = dbquery($query); $row = dbarray($result); ob_clean(); loca_add("battlereport"); ?> <html> <HEAD> <LINK rel="stylesheet" type="text/css" href="<?php echo UserSkin(); ?> formate.css"> <meta http-equiv="content-type" content="text/html; charset=UTF-8" /> <TITLE><?php echo loca("BATTLE_REPORT"); ?> </TITLE> <script src="js/utilities.js" type="text/javascript"></script> <script type="text/javascript" src="js/overLib/overlib.js"></script> <script language="JavaScript">var session="<?php echo $session; ?> ";</script> </HEAD> <BODY> <div id="overDiv" style="position:absolute; visibility:hidden; z-index:1000;"></div> <table width="99%"> <tr> <td> <?php echo $row['report']; ?> </td> </tr> </table> </BODY> </html> <?php ob_end_flush(); die; } // Вывести список всех докладов $query = "SELECT * FROM " . $db_prefix . "battledata ORDER BY date DESC"; $result = dbquery($query); echo "<table>"; while ($row = dbarray($result)) { echo "<tr><td>" . date("Y.m.d H:i:s", $row['date']) . "</td><td>" . str_replace("{PUBLIC_SESSION}", $session, $row['title']) . "</td></tr>"; } echo "</table>"; ?> <?php }
function Admin_UserLogs() { global $session; global $db_prefix; global $GlobalUser; // Обработка POST-запроса. if (method() === "POST" && $GlobalUser['admin'] >= 1) { $name = $_POST['name']; $type = $_POST['type']; $period = intval($_POST['days']) * 24 * 60 * 60 + intval($_POST['hours']) * 60 * 60; $arr = My_date_parse_from_format("dd.mm.yyyy", $_POST['since']); $since = mktime(0, 0, 0, $arr['month'], $arr['day'], $arr['year']); // Шаг 1 : найти всех пользователей неточным сравнением $users = array(); $query = "SELECT * FROM " . $db_prefix . "users WHERE player_id > 0"; $result = dbquery($query); while ($user = dbarray($result)) { $percent = 0; similar_text(mb_strtolower($name), mb_strtolower($user['oname']), &$percent); if ($percent > 75) { $users[] = $user; } } // Шаг 2 : выбрать события указанной категории за промежуток времени $results = ""; foreach ($users as $i => $user) { if ($type !== "ALL") { $tstr = "AND type = '" . $type . "'"; } $query = "SELECT * FROM " . $db_prefix . "userlogs WHERE owner_id = " . $user['player_id'] . " AND (date >= " . $since . " AND date <= " . ($since + $period) . ") " . $tstr . " ORDER BY date ASC"; $result = dbquery($query); $count = dbrows($result); $results .= "<h2>История {$type} игрока " . AdminUserName($user) . " ({$count})</h2>\n"; $results .= "<table><tr><td class=\"c\">Дата</td><td class=\"c\">Тип</td><td class=\"c\">Действие</td></tr>\n"; while ($log = dbarray($result)) { $results .= "<tr><td>" . date("d.m.Y H:i:s", $log['date']) . "</td><td>" . $log['type'] . "</td><td>" . $log['text'] . "</td></tr>\n"; } $results .= "</table>"; } } ?> <?php echo AdminPanel(); ?> <?php if (method() === "GET") { $query = "SELECT * FROM " . $db_prefix . "userlogs WHERE owner_id > 0 ORDER BY date DESC LIMIT 50"; $result = dbquery($query); echo "<h2>Последние действия игроков</h2>\n"; echo "<table><tr><td class=\"c\">Дата</td><td class=\"c\">Игрок</td><td class=\"c\">Категория</td><td class=\"c\">Действие</td></tr>\n"; $rows = array(); while ($log = dbarray($result)) { $user = LoadUser($log['owner_id']); $rows[] = "<tr><td>" . date("d.m.Y H:i:s", $log['date']) . "</td><td>" . AdminUserName($user) . "</td><td>" . $log['type'] . "</td><td>" . $log['text'] . "</td></tr>\n"; } $rows = array_reverse($rows); foreach ($rows as $i => $row) { echo $row; } echo "</table>"; } ?> <?php echo $results; ?> <h2>История действий</h2> <table> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=UserLogs" method="POST" > <tr><td>Имя пользователя</td><td><input type="text" size=20 name="name"/> (можно примерно)</td></tr> <tr><td>Категория</td><td> <select name="type"> <option value="ALL">Все</option> <option value="BUILD">Постройки / Снос</option> <option value="RESEARCH">Исследования</option> <option value="SHIPYARD">Постройка флота</option> <option value="DEFENSE">Постройка обороны</option> <option value="FLEET">Отправка флота</option> <option value="PLANET">Настройки планеты</option> <option value="SETTINGS">Изменение настроек аккаунта / РО</option> <option value="OPER">Действия оператора</option> </select> </td></tr> <tr><td>За период</td><td><input type="text" size=2 name="days" value="2"/> дн. <input type="text" size=2 name="hours"/> ч.</td></tr> <tr><td>Начиная с</td><td><input type="text" size=20 name="since" value="<?php echo date("d.m.Y", time() - 24 * 60 * 60); ?> "/> ДД.ММ.ГГГ</td></tr> <tr><td class="c" colspan=2> <input type="submit" value="Отправить" /></td></tr> </form> </table> <?php }
function Admin_Uni() { global $db_prefix; global $GlobalUser; global $session; $now = time(); if (method() === "POST" && $GlobalUser['admin'] >= 2) { if (key_exists('news_upd', $_POST)) { if ($_POST['news_upd'] > 0) { UpdateNews($_POST['news1'], $_POST['news2'], $_POST['news_upd']); } } if ($_POST['news_off'] === "on") { DisableNews(); } $rapid = $_POST['rapid'] === "on" ? 1 : 0; $moons = $_POST['moons'] === "on" ? 1 : 0; $freeze = $_POST['freeze'] === "on" ? 1 : 0; SetUniParam($_POST['speed'], $_POST['fspeed'], $_POST['acs'], $_POST['fid'], $_POST['did'], $_POST['defrepair'], $_POST['defrepair_delta'], $_POST['galaxies'], $_POST['systems'], $rapid, $moons, $freeze); // Включить принудительное РО активным игрокам, если вселенная ставится на паузу. if ($freeze) { $days7 = $now - 7 * 24 * 60 * 60; $query = "UPDATE " . $db_prefix . "users SET vacation = 1, vacation_until = " . $now . " WHERE lastclick >= {$days7}"; dbquery($query); } //print_r ( $_POST ); } $unitab = LoadUniverse(); ?> <?php echo AdminPanel(); ?> <table > <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Uni" method="POST" > <tr><td class=c colspan=2>Настройки Вселенной <?php echo $unitab['num']; ?> </td></tr> <tr><th>Дата открытия</th><th><?php echo date("Y-m-d H:i:s", $unitab['startdate']); ?> </th></tr> <tr><th>Количество игроков</th><th><?php echo $unitab['usercount']; ?> </th></tr> <tr><th>Максимальное количество игроков</th><th><input type="text" name="maxusers" maxlength="10" size="10" value="<?php echo $unitab['maxusers']; ?> " /></th></tr> <tr><th>Количество галактик</th><th><input type="text" name="galaxies" maxlength="3" size="3" value="<?php echo $unitab['galaxies']; ?> " /></th></tr> <tr><th>Количество систем в галактике</th><th><input type="text" name="systems" maxlength="3" size="3" value="<?php echo $unitab['systems']; ?> " /></th></tr> <tr> <th>Ускорение игры</th> <th> <select name="speed"> <option value="1" <?php echo UniIsSelected($unitab['speed'], 1); ?> >1x</option> <option value="2" <?php echo UniIsSelected($unitab['speed'], 2); ?> >2x</option> <option value="3" <?php echo UniIsSelected($unitab['speed'], 3); ?> >3x</option> <option value="4" <?php echo UniIsSelected($unitab['speed'], 4); ?> >4x</option> <option value="5" <?php echo UniIsSelected($unitab['speed'], 5); ?> >5x</option> <option value="6" <?php echo UniIsSelected($unitab['speed'], 6); ?> >6x</option> <option value="7" <?php echo UniIsSelected($unitab['speed'], 7); ?> >7x</option> <option value="8" <?php echo UniIsSelected($unitab['speed'], 8); ?> >8x</option> <option value="9" <?php echo UniIsSelected($unitab['speed'], 9); ?> >9x</option> <option value="10" <?php echo UniIsSelected($unitab['speed'], 10); ?> >10x</option> </select> </th> </tr> <tr> <th>Ускорение флота</th> <th> <select name="fspeed"> <option value="1" <?php echo UniIsSelected($unitab['fspeed'], 1); ?> >1x</option> <option value="2" <?php echo UniIsSelected($unitab['fspeed'], 2); ?> >2x</option> <option value="3" <?php echo UniIsSelected($unitab['fspeed'], 3); ?> >3x</option> <option value="4" <?php echo UniIsSelected($unitab['fspeed'], 4); ?> >4x</option> <option value="5" <?php echo UniIsSelected($unitab['fspeed'], 5); ?> >5x</option> <option value="6" <?php echo UniIsSelected($unitab['fspeed'], 6); ?> >6x</option> <option value="7" <?php echo UniIsSelected($unitab['fspeed'], 7); ?> >7x</option> <option value="8" <?php echo UniIsSelected($unitab['fspeed'], 8); ?> >8x</option> <option value="9" <?php echo UniIsSelected($unitab['fspeed'], 9); ?> >9x</option> <option value="10" <?php echo UniIsSelected($unitab['fspeed'], 10); ?> >10x</option> </select> </th> </tr> <tr> <th>Флот в обломки</th> <th> <select name="fid"> <option value="0" <?php echo UniIsSelected($unitab['fid'], 0); ?> >0%</option> <option value="10" <?php echo UniIsSelected($unitab['fid'], 10); ?> >10%</option> <option value="20" <?php echo UniIsSelected($unitab['fid'], 20); ?> >20%</option> <option value="30" <?php echo UniIsSelected($unitab['fid'], 30); ?> >30%</option> <option value="40" <?php echo UniIsSelected($unitab['fid'], 40); ?> >40%</option> <option value="50" <?php echo UniIsSelected($unitab['fid'], 50); ?> >50%</option> <option value="60" <?php echo UniIsSelected($unitab['fid'], 60); ?> >60%</option> <option value="70" <?php echo UniIsSelected($unitab['fid'], 70); ?> >70%</option> <option value="80" <?php echo UniIsSelected($unitab['fid'], 80); ?> >80%</option> <option value="90" <?php echo UniIsSelected($unitab['fid'], 90); ?> >90%</option> <option value="100" <?php echo UniIsSelected($unitab['fid'], 100); ?> >100%</option> </select> </th> </tr> <tr> <th>Оборона в обломки</th> <th> <select name="did"> <option value="0" <?php echo UniIsSelected($unitab['did'], 0); ?> >0%</option> <option value="10" <?php echo UniIsSelected($unitab['did'], 10); ?> >10%</option> <option value="20" <?php echo UniIsSelected($unitab['did'], 20); ?> >20%</option> <option value="30" <?php echo UniIsSelected($unitab['did'], 30); ?> >30%</option> <option value="40" <?php echo UniIsSelected($unitab['did'], 40); ?> >40%</option> <option value="50" <?php echo UniIsSelected($unitab['did'], 50); ?> >50%</option> <option value="60" <?php echo UniIsSelected($unitab['did'], 60); ?> >60%</option> <option value="70" <?php echo UniIsSelected($unitab['did'], 70); ?> >70%</option> <option value="80" <?php echo UniIsSelected($unitab['did'], 80); ?> >80%</option> <option value="90" <?php echo UniIsSelected($unitab['did'], 90); ?> >90%</option> <option value="100" <?php echo UniIsSelected($unitab['did'], 100); ?> >100%</option> </select> </th> </tr> <tr><th>Восстановление обороны</th><th> <input type="text" name="defrepair" maxlength="3" size="3" value="<?php echo $unitab['defrepair']; ?> " /> +/- <input type="text" name="defrepair_delta" maxlength="3" size="3" value="<?php echo $unitab['defrepair_delta']; ?> " /> % </th></tr> <tr><th>Приглашенных игроков в САБ</th><th><input type="text" name="acs" maxlength="3" size="3" value="<?php echo $unitab['acs']; ?> " /> (макс. <?php echo $unitab['acs'] * $unitab['acs']; ?> флотов)</th></tr> <tr><th>Скорострел</th><th><input type="checkbox" name="rapid" <?php echo UniIsChecked($unitab['rapid']); ?> /></th></tr> <tr><th>Луны и Звёзды Смерти</th><th><input type="checkbox" name="moons" <?php echo UniIsChecked($unitab['moons']); ?> /></th></tr> <tr><th>Новость 1</th><th><input type="text" name="news1" maxlength="99" size="20" value="<?php echo $unitab['news1']; ?> " /></th></tr> <tr><th>Новость 2</th><th><input type="text" name="news2" maxlength="99" size="20" value="<?php echo $unitab['news2']; ?> " /></th></tr> <?php if ($now > $unitab['news_until']) { echo "<tr><th>Продлить новость</th><th><input type=\"text\" name=\"news_upd\" maxlength=\"3\" size=\"3\" value=\"0\" /> дн.</th></tr>\n"; } else { echo "<tr><th>Показывать новость до</th><th>" . date("Y-m-d H:i:s", $unitab['news_until']) . " <input type=\"checkbox\" name=\"news_off\" /> убрать</th></tr>\n"; } ?> <tr><th>Поставить вселенную на паузу</th><th><input type="checkbox" name="freeze" <?php echo UniIsChecked($unitab['freeze']); ?> /></th></tr> <tr><th colspan=2><input type="submit" value="Сохранить" /></th></tr> </form> </table> <?php }
function Admin_Botedit() { global $session; global $db_prefix; global $GlobalUser, $GlobalUni; // Обработка GET-запроса. if (method() === "GET") { if ($_GET['action'] === "preview") { // Предпросмотр $id = intval($_GET['strat']); $query = "SELECT * FROM " . $db_prefix . "botstrat WHERE id = {$id} LIMIT 1"; $result = dbquery($query); $row = dbarray($result); ob_clean(); ?> <html> <head> <link rel='stylesheet' type='text/css' href='css/default.css' /> <link rel='stylesheet' type='text/css' href='css/formate.css' /> <script language="JavaScript">var session="<?php echo $session; ?> ";</script> <meta http-equiv='content-type' content='text/html; charset=UTF-8' /> <link rel='stylesheet' type='text/css' href='css/combox.css'> <link rel='stylesheet' type='text/css' href='<?php echo UserSkin(); ?> formate.css' /> <title><?php echo $row['name']; ?> </title> <script src='js/utilities.js' type='text/javascript'></script> <script language='JavaScript'> </script> </head> <body> <script type="text/javascript" src="js/tw-sack.js"></script> <script type="text/javascript" src="js/go.js"></script> <script type="text/javascript" src="js/go-game.js"></script> <div id="sample"> <div style="width:100%; white-space:nowrap; display:none;"> <span style="display: inline-block; vertical-align: top; padding: 5px; width:100px"> <div id="myPalette" style="background-color: #344566; border: solid 1px black; height: 500px"></div> </span> <span style="display: inline-block; vertical-align: top; padding: 5px; width:88%"> <div id="myDiagram" style="background-color: #344566; border: solid 1px black; height: 500px"></div> </span> </div> <input type="text" size="50" id="strategyName" style="display:none;"> <select id="strategyId" style="display:none;"> <option value="<?php echo $row['id']; ?> " selected><?php echo $row['id']; ?> </option> </select> <textarea id="mySavedModel" style="width:100%;height:300px; display:none;"> <?php echo $row['source']; ?> </textarea> </div> <img src="" id="preview_img"> <script type="text/javascript"> init (); </script> </body> </html> <?php die; } } // Обработка POST-запроса. if (method() === "POST") { if ($_POST['action'] === "load") { // Загрузить $id = intval($_POST['strat']); $query = "SELECT * FROM " . $db_prefix . "botstrat WHERE id = {$id} LIMIT 1"; $result = dbquery($query); $row = dbarray($result); ob_clean(); setcookie("uni" . $GlobalUni['num'] . "_" . $GlobalUser['name'] . "_strategy", $id, 9999); die($row['source']); } else { if ($_POST['action'] === "save") { // Сохранить $id = intval($_POST['strat']); // Сохранить текущий исходник в бекап $query = "SELECT * FROM " . $db_prefix . "botstrat WHERE id = {$id} LIMIT 1"; $result = dbquery($query); $row = dbarray($result); $query = "UPDATE " . $db_prefix . "botstrat SET source = '" . $row['source'] . "' WHERE id = 1;"; dbquery($query); $source = urldecode($_POST['source']); $source = addslashes($source); $query = "UPDATE " . $db_prefix . "botstrat SET source = '" . $source . "' WHERE id = {$id};"; dbquery($query); ob_clean(); die; } else { if ($_POST['action'] === "new") { // Новая стратегия $name = $_POST['name']; $name = addslashes($name); $source = "{ \"class\": \"go.GraphLinksModel\",\r\n \"linkFromPortIdProperty\": \"fromPort\",\r\n \"linkToPortIdProperty\": \"toPort\",\r\n \"nodeDataArray\": [ ],\r\n \"linkDataArray\": [ ]}"; $strat = array('', $name, $source); AddDBRow($strat, 'botstrat'); ob_clean(); die; } else { if ($_POST['action'] === "rename") { // Переименовать $id = intval($_POST['strat']); $name = $_POST['name']; $name = addslashes($name); $query = "UPDATE " . $db_prefix . "botstrat SET name = '" . $name . "' WHERE id = {$id};"; dbquery($query); ob_clean(); $query = "SELECT * FROM " . $db_prefix . "botstrat ORDER BY id ASC"; $result = dbquery($query); echo "<option value=\"0\">-- Выберите стратегию --</option>\n"; while ($row = dbarray($result)) { echo "<option value=\"" . $row['id'] . "\" "; if ($row['id'] == $id) { echo "selected"; } echo ">" . stripslashes($row['name']) . "</option>\n"; } die; } else { ob_clean(); die; } } } } } ?> <script type="text/javascript" src="js/tw-sack.js"></script> <script type="text/javascript" src="js/go.js"></script> <script type="text/javascript" src="js/go-game.js"></script> <?php echo AdminPanel(); ?> <div id="sample"> <div style="width:100%; white-space:nowrap;"> <span style="display: inline-block; vertical-align: top; padding: 5px; width:100px"> <div id="myPalette" style="background-color: #344566; border: solid 1px black; height: 500px"></div> </span> <span style="display: inline-block; vertical-align: top; padding: 5px; width:88%"> <div id="myDiagram" style="background-color: #344566; border: solid 1px black; height: 500px"></div> </span> </div> <span style="float:left;"> <input type="text" size="50" id="strategyName"> <button onclick="newstrat()">Новая</button> <button onclick="rename()">Переименовать</button> <button onclick="showimg()">Показать</button> </span> <span style="float:right;"> <button onclick="save()">Сохранить</button> <select id="strategyId"> <option value="0">-- Выберите стратегию --</option> <?php $query = "SELECT * FROM " . $db_prefix . "botstrat ORDER BY id ASC"; $result = dbquery($query); while ($row = dbarray($result)) { echo "<option value=\"" . $row['id'] . "\">" . stripslashes($row['name']) . "</option>\n"; } ?> </select> <button onclick="load()">Загрузить</button> </span> <textarea id="mySavedModel" style="width:100%;height:300px; display:none;"> { "class": "go.GraphLinksModel", "linkFromPortIdProperty": "fromPort", "linkToPortIdProperty": "toPort", "nodeDataArray": [ ], "linkDataArray": [ ]} </textarea> </div> <script type="text/javascript"> init (); </script> <img src="" id="preview_img" style="display:none;"> <?php }
function Admin_Coupons() { global $session; global $db_prefix; global $GlobalUser; global $AdminMessage, $AdminError; // Обработка POST-запроса. if (method() === "POST" && $GlobalUser['admin'] >= 2) { $action = $_GET['action']; if ($action === "add_one") { $code = AddCoupon(intval($_POST['dm'])); if ($code == NULL) { $AdminError = "<font color=red>Ошибка добавления купона!</font>"; } else { $AdminMessage = "<font color=lime>Купон добавлен : {$code}</font>"; } } if ($action === "add_date") { $ddmm = explode('.', $_POST['ddmm']); $hhmm = explode(':', $_POST['hhmm']); $now = time(); $end = mktime($hhmm[0], $hhmm[1], 0, $ddmm[1], $ddmm[0]); $inactive_days = intval($_POST['inactive_days']); $ingame_days = intval($_POST['ingame_days']); $darkmatter = intval($_POST['darkmatter']); $periodic = intval($_POST['periodic']); $queue = array(null, 99999, "Coupon", $darkmatter, $inactive_days << 16 | $ingame_days, $periodic, $now, $end, 520); AddDBRow($queue, "queue"); } } // Обработка GET-запроса. if (method() === "GET" && $GlobalUser['admin'] >= 2) { $action = $_GET['action']; if ($action === "remove_one") { DeleteCoupon($_GET['item_id']); } if ($action === "remove_date") { RemoveQueue($_GET['item_id']); } } ?> <?php echo AdminPanel(); ?> <?php // Вывести список купонов. $count = 15; // количество купонов на страницу $from = intval($_GET['from']); $total = TotalCoupons(); $result = EnumCoupons($from, $count); $rows = MDBRows($result); ?> <table border="0" cellpadding="2" cellspacing="1"> <tr height="20"> <td class="c">Код</td> <td class="c">Тёмная материя</td> <td class="c">Активирован</td> <td class="c">Вселенная</td> <td class="c">Имя игрока</td> <td class="c">Действие</td> </tr> <?php while ($rows--) { $entry = MDBArray($result); echo " <tr height=\"20\">\n"; echo " <th>" . $entry['code'] . "</th>\n"; echo " <th>" . nicenum($entry['amount']) . "</th>\n"; echo " <th>" . ($entry['used'] ? "<font color=red>Да</font>" : "<font color=lime>Нет</font>") . "</th>\n"; echo " <th>" . ($entry['used'] ? $entry['user_uni'] : '-') . "</th>\n"; echo " <th>" . $entry['user_name'] . "</th>\n"; echo " <th><a href=\"index.php?page=admin&session={$session}&mode=Coupons&action=remove_one&item_id=" . $entry['id'] . "\">Удалить</a></th>\n"; echo " </tr>\n"; } ?> <tr> <th colspan="6"> <?php $url = "index.php?page=admin&session={$session}&mode=Coupons&from"; if ($from >= $count) { echo " <a href=\"" . $url . "=" . ($from - $count) . "\"><< Предыдущие {$count}</a> \n"; } if ($from < $total && $from + $count < $total) { echo " <a href=\"" . $url . "=" . ($from + $count) . "\">Следующие {$count} >></a>\n"; } ?> </th> </tr> </table> <table> <tr><td class="c">Добавить один купон</td></tr> <tr><td> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Coupons&action=add_one" method="POST"> Темная материя <input type="text" size="10" name="dm"> <input type="submit"> </form> </td></tr> </table> <?php // Вывести активные задания начисления купонов. $query = "SELECT * FROM " . $db_prefix . "queue WHERE type = 'Coupon' ORDER BY end ASC"; $result = dbquery($query); while ($queue = dbarray($result)) { print_r($queue); echo "<br>"; } ?> <form action="index.php?page=admin&session=<?php echo $session; ?> &mode=Coupons&action=add_date" method="POST"> <table> <tr><td class="c"colspan=2>Купоны по праздникам</td></tr> <tr><td>День в формате ДД.ММ <input type="text" size="10" name="ddmm"></td><td>Время в формате ЧЧ:ММ <input type="text" size="10" name="hhmm" value="10:00"></td></tr> <tr><td>Темной материи на купон</td><td><input type="text" size="10" name="darkmatter" value="100000"> </td></tr> <tr><td>Отправлять игрокам неактивным не менее</td><td><input type="text" size="10" name="inactive_days" value="7"> дней</td></tr> <tr><td>Игроки должны играть не менее</td><td><input type="text" size="10" name="ingame_days" value="365"> дней</td></tr> <tr><td>Периодичность дней (0-без периодичности)</td><td><input type="text" size="10" name="periodic" value="365"> </td></tr> <tr><td colspan=2><input type="submit"></td></tr> </table> </form> <?php }